## Наиболее полное справочное руководство

Михаил Гук

Стандарты и расширения Программирование Конструктивные элементы

Схемотехника



# 

## Интерфейсы ПК Справочник

Это наиболее полный справочник, содержащий всю необходимую информацию, которая может нопадобиться разработчику периферийных устройств. Вам не придется перерывать горы литературы или тратить свои дены и на поиск информации в Интернете для того, чтобы найти ответ на интересующий вас вопрос.

Удобное расположение и системат изация материала и подробный алфавитный указатель делают книгу незаменимым консулы антом, который всегда под рукой на вашем рабочем столе.

«Интерфейсы ПК: справочник» « настольная книга и профессионаларазработчика, и программиста, и опытного пользователя!

#### Уровень пользователя

- Начинающий Опытный Профессионал

Категория книги-

Справочник Апнаратные средства

Михаил Гук



Информация, которую вы найдете в справочнике:

- Параллельные ннтерфейсы (Centronics н LPT-порт)
- Стандарт IEEE 1284-1994
- Последовательные интерфейсы (RS-232C, MIDI, «токовая петля»)
- Спецнальные интерфейсы (клавнатура, мышь, GAME-порт)
- Аудноинтерфейсы
- Иитерфейсы мониторов (RGB TTL, analog, EVC)
- IIIины расширения (ISA, EISA, PC-104, MCA, VLB, PCI, AGP, PCMCIA)
- Интерфейс ATA, ATAPI, SCSI
- Последовательные инины (USB, FireWire, ACCESS, Bus, 1<sup>2</sup>C)
- (USB, FireWire, ACCESS, Bus, FC
   Системотехника IBM PC
   (память, ввод/вывод,
- прерывання, Plug and Play)

  Конструктивные элементы

компьютеров и интерфейсов

■ Элемевты цифровой схемотехники и многое другое

> Лучший подарок

На каждый вопрос готов ответ!



## Интерфейсы ПК Справочник

Санкт-Петербург Москва • Харьков • Минск



#### Михаил Гук

#### Интерфейсы ПК: справочник

Главный редактор В. Усманов Заведующий редакцией Е. Строганова Ведущий редактор А. Пасечник Литературный редактор Ф. Андреев Художественный редактор И. Половодов Иллюстрации Ο. Γνκ Корректоры Н. Рощина, С. Шевякова Верстка П. Быстров

ББК 32.973.2-04я22

УДК 681.326(03)

Гук М.

Г93 Интерфейсы ПК: справочник — СПб: ЗАО «Издательство «Питер», 1999. — 416 с.: ил.

Наиболее полный и подробный справочник по всем внутренним и

ISBN 5-8046-0030-3

внешним интерфейсам персонального компьютера: последовательного и параллельного портов, инфракрасного порта, IDE, SCSI, шинам ISA, EISA, MCA, VESA, PCI, AGP, PC-Card (PCIMCIA) и др. В книге приводятся полные описания и спецификации интерфейсов: от адресов ввода/вывода и

прерываний до уровней сигналов и контактов разъемов.

Для программистов, инженеров и разработчиков периферийного оборудования.

© М. Гук, 1999

© Серия, оформление, ЗАО «Издательство «Питер», 1999

#### ISBN 5-8046-0030-3

Все упомянутые в данном издании товарные знаки и зарегистрированные товарные знаки принадлежат своим законным владельцам.

Информация, содержащаяся в данной книге, получена из источников, рассматриваемых издательством как надежные. Тем не менее, имея в виду возможные человеческие или технические ошибки, издательство не может гарантировать абсолютную точность и полноту приводимых сведений и не несет ответственности за возможные ошибки, связанные с использованием книги.

ЛР № 066333 от 23.02.99 г.

Подписано к печати 23.02.99. Формат 84х108<sup>1</sup>/<sub>32</sub>. Усл. п. л. 43,68. Доп. тираж 7000 экз. от 03.03.99 г. Заказ № 530.

ЗАО «Издательство «Питер». 196105, Санкт-Петербург, Благодатная ул., 67. Оптечатано с готовых диапозитивов в ГИПК «Лениздат». (тительный им. Возгодовых диапозитивов в ГИПК «Лениздат».

(типография им. Володарского) Государственного комитета РФ по печати. 191023, С.-Петербург, наб. р. Фонтанки, 59.

## Содержание

| Предисловие                                      | 9  |
|--------------------------------------------------|----|
| Введение                                         | 11 |
| 1. Параллельные интерфейсы                       | 17 |
| 1.1. Интерфейс Centronics и LPT-порт             | 17 |
| 1.1.1. Интерфейс Centronics                      |    |
| 1.1.2. Традиционный LPT-порт                     |    |
| 1.1.3. Расширения параллельного порта            | 24 |
| 1.2. Стандарт IEEE 1284                          | 24 |
| 1.2.1. Физический и электрический интерфейсы     |    |
| 1.2.2. Режимы передачи данных                    |    |
| 1.2.3. Согласование режимов IEEE 1284            |    |
| 1.2.4. Развитие стандарта IEEE 1284              | 49 |
| 1.3. Применение параллельных интерфейсов         |    |
| и LPT-портов                                     | 50 |
| 1.3.1. Использование параллельных интерфейсов    |    |
| 1.3.2. Конфигурирование LPT-портов               | 56 |
| 1.3.3. Неисправности и тестирование параллельных |    |
| портов                                           |    |
| 1.3.4. Функции BIOS для LPT-порта                | 62 |
| 2. Последовательные интерфейсы                   | 64 |

 2.1. Способы последовательной передачи
 64

 2.2. Интерфейс RS-232C
 68

 2.2.1. Электрический интерфейс
 69

 2.2.2. Управление потоком данных
 74

 2.3. Интерфейс «токовая петля»
 77

 2.4. Интерфейс MIDI
 79

 2.5. COM-порт
 82

|    | 2.5.1. Использование СОМ-портов                                                                                                                                                                                                                                                                                                                                                                                                                                               | 83                                                                                |
|----|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------|
|    | 2.5.2. Микросхемы асинхронных приемопередатчиков                                                                                                                                                                                                                                                                                                                                                                                                                              | 87                                                                                |
|    | 2.5.3. Ресурсы и конфигурирование СОМ-портов                                                                                                                                                                                                                                                                                                                                                                                                                                  | 95                                                                                |
|    | 2.5.4. Неисправности и тестирование СОМ-портов                                                                                                                                                                                                                                                                                                                                                                                                                                | 97                                                                                |
|    | 2.5.5. Функции BIOS для COM-портов                                                                                                                                                                                                                                                                                                                                                                                                                                            | 02                                                                                |
|    | 2.5.6. СОМ-порт и РпР 1                                                                                                                                                                                                                                                                                                                                                                                                                                                       | .05                                                                               |
| 3. | . Специальные интерфейсы1                                                                                                                                                                                                                                                                                                                                                                                                                                                     | 07                                                                                |
|    | 3.1. Интерфейс клавиатуры 1                                                                                                                                                                                                                                                                                                                                                                                                                                                   | 07                                                                                |
|    | 3.2. Интерфейсы манипуляторов 1                                                                                                                                                                                                                                                                                                                                                                                                                                               | 12                                                                                |
|    | 3.3. Интерфейс игрового адаптера — GAME-порт 1                                                                                                                                                                                                                                                                                                                                                                                                                                | 14                                                                                |
|    | 3.4. Аудиоинтерфейсы 1                                                                                                                                                                                                                                                                                                                                                                                                                                                        | 17                                                                                |
|    | 3.4.1. PC Speaker 1                                                                                                                                                                                                                                                                                                                                                                                                                                                           |                                                                                   |
|    | 3.4.2. Цифровой аудиоканал 1                                                                                                                                                                                                                                                                                                                                                                                                                                                  | 18                                                                                |
|    | 3.5. Интерфейсы видеомониторов 1                                                                                                                                                                                                                                                                                                                                                                                                                                              |                                                                                   |
|    | 3.5.1. Дискретный интерфейс RGB TTL 1                                                                                                                                                                                                                                                                                                                                                                                                                                         | 23                                                                                |
|    | 3.5.2. Аналоговый интерфейс RGB 1                                                                                                                                                                                                                                                                                                                                                                                                                                             | 24                                                                                |
|    | 3.5.3. Комбинированный интерфейс EVC1                                                                                                                                                                                                                                                                                                                                                                                                                                         | 30                                                                                |
|    |                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                                                                                   |
| 4. | Шины расширения 15                                                                                                                                                                                                                                                                                                                                                                                                                                                            | 32                                                                                |
| 4. | •                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                                                                                   |
| 4. | 4.1. Шины ISA, EISA и PC-104 1                                                                                                                                                                                                                                                                                                                                                                                                                                                | 36                                                                                |
| 4. | 4.1. Шины ISA, EISA и PC-104 1<br>4.2. Шина MCA                                                                                                                                                                                                                                                                                                                                                                                                                               | 36<br>49                                                                          |
| 4. | 4.1. Шины ISA, EISA и PC-104       1         4.2. Шина MCA       1         4.3. Локальная шина VLB       1                                                                                                                                                                                                                                                                                                                                                                    | 36<br>49<br>50                                                                    |
| 4. | 4.1. Шины ISA, EISA и PC-104       1         4.2. Шина MCA       1         4.3. Локальная шина VLB       1         4.4. Шина PCI       1                                                                                                                                                                                                                                                                                                                                      | 36<br>49<br>50<br>54                                                              |
| 4. | 4.1. Шины ISA, EISA и PC-104       1         4.2. Шина MCA       1         4.3. Локальная шина VLB       1                                                                                                                                                                                                                                                                                                                                                                    | 36<br>49<br>50<br>54<br>68                                                        |
|    | 4.1. Шины ISA, EISA и PC-104       1         4.2. Шина МСА       1         4.3. Локальная шина VLB       1         4.4. Шина PCI       1         4.5. Магистральный интерфейс AGP       1         4.6. Шины PCMCIA (PC Card)       1                                                                                                                                                                                                                                          | 36<br>49<br>50<br>54<br>68<br>73                                                  |
|    | 4.1. Шины ISA, EISA и PC-104       1         4.2. Шина МСА       1         4.3. Локальная шина VLB       1         4.4. Шина PCI       1         4.5. Магистральный интерфейс AGP       1         4.6. Шины PCMCIA (PC Card)       1         1       1         1       1         5.1. Физический интерфейс       1                                                                                                                                                            | 36<br>49<br>50<br>54<br>68<br>73<br><b>76</b>                                     |
|    | 4.1. Шины ISA, EISA и PC-104       1         4.2. Шина МСА       1         4.3. Локальная шина VLB       1         4.4. Шина PCI       1         4.5. Магистральный интерфейс AGP       1         4.6. Шины PCMCIA (PC Card)       1         5.1. Физический интерфейс       1         5.2. Фазы шины       1                                                                                                                                                                 | 36<br>49<br>50<br>54<br>68<br>73<br><b>76</b><br>80<br>89                         |
|    | 4.1. Шины ISA, EISA и PC-104       1         4.2. Шина MCA       1         4.3. Локальная шина VLB       1         4.4. Шина PCI       1         4.5. Магистральный интерфейс AGP       1         4.6. Шины PCMCIA (PC Card)       1         5.1. Физический интерфейс       1         5.2. Фазы шины       1         5.3. Управление интерфейсом       1                                                                                                                     | 36<br>49<br>50<br>54<br>68<br>73<br><b>76</b><br>80<br>89<br>95                   |
|    | 4.1. Шины ISA, EISA и PC-104       1         4.2. Шина MCA       1         4.3. Локальная шина VLB       1         4.4. Шина PCI       1         4.5. Магистральный интерфейс AGP       1         4.6. Шины PCMCIA (PC Card)       1         5.1. Физический интерфейс       1         5.2. Фазы шины       1         5.3. Управление интерфейсом       1         5.4. Типы ПУ       2                                                                                        | 36<br>49<br>50<br>54<br>68<br>73<br><b>76</b><br>80<br>89<br>95<br>00             |
|    | 4.1. Шины ISA, EISA и PC-104       1         4.2. Шина MCA       1         4.3. Локальная шина VLB       1         4.4. Шина PCI       1         4.5. Магистральный интерфейс AGP       1         4.6. Шины PCMCIA (PC Card)       1         5.1. Физический интерфейс       1         5.2. Фазы шины       1         5.3. Управление интерфейсом       1         5.4. Типы ПУ       2         5.5. Адресация и система команд       2                                        | 36<br>49<br>50<br>54<br>68<br>73<br><b>76</b><br>80<br>89<br>95<br>00<br>06       |
|    | 4.1. Шины ISA, EISA и PC-104       1         4.2. Шина MCA       1         4.3. Локальная шина VLB       1         4.4. Шина PCI       1         4.5. Магистральный интерфейс AGP       1         4.6. Шины PCMCIA (PC Card)       1         5.1. Физический интерфейс       1         5.2. Фазы шины       1         5.3. Управление интерфейсом       1         5.4. Типы ПУ       2         5.5. Адресация и система команд       2         5.6. Выполнение команд       2 | 36<br>49<br>50<br>54<br>68<br>73<br><b>76</b><br>80<br>89<br>95<br>00<br>06<br>16 |
|    | 4.1. Шины ISA, EISA и PC-104       1         4.2. Шина MCA       1         4.3. Локальная шина VLB       1         4.4. Шина PCI       1         4.5. Магистральный интерфейс AGP       1         4.6. Шины PCMCIA (PC Card)       1         5.1. Физический интерфейс       1         5.2. Фазы шины       1         5.3. Управление интерфейсом       1         5.4. Типы ПУ       2         5.5. Адресация и система команд       2                                        | 36<br>49<br>50<br>54<br>68<br>73<br><b>76</b><br>80<br>89<br>95<br>00<br>06<br>16 |

| 6. Интерфейс АТА 22                                            | 3   |
|----------------------------------------------------------------|-----|
| 6.1. Электрический интерфейс22                                 | 27  |
| 6.2. Регистры устройств                                        |     |
| 6.3. Система команд                                            |     |
| 6.3.1. Основные команды                                        |     |
| 6.3.2. Служебные команды                                       |     |
| 6.3.3. Дополнительные сервисные функции                        | 9   |
| 6.4. Протоколы взаимодействия хоста и устройства 26            | 3   |
| 6.5. Протоколы и режимы передачи данных                        | 6   |
| 6.6. Средства многозадачности (АТА-4)                          |     |
| 6.7. Пакетный интерфейс АТАРІ27                                |     |
| 6.8. Адаптеры шины ATA и категории устройств IDE 27            | 9   |
| 6.9. Конфигурирование устройств28                              | 32  |
| - <b>-</b>                                                     |     |
| 7. Последовательные шины 28                                    | 5   |
| 7.1. Шина USB 28                                               | 35  |
| 7.1.1. Структура USB 28                                        |     |
| 7.1.2. Системное конфигурирование                              | 0   |
| 7.1.3. Устройства USB — функции и хабы 30                      | 2   |
| 7.1.4. Хост-контроллер                                         |     |
| 7.2. Шина IEEE 1394 — FireWire 30                              |     |
| 7.2.1. Структура и взаимодействие устройств шины 30            |     |
| 7.2.2. Синонимы и дополнения стандарта IEEE 1394 31            |     |
| 7.2.3. Сравнение FireWire и USB                                |     |
| 7.3. Шина ACCESS.Bus и интерфейс I <sup>2</sup> C              | 4   |
| Приложение А. Системотехника IBM РС-совместимых компьютеров 32 | 0   |
|                                                                |     |
| А.1. Пространство памяти                                       |     |
| А.2. Пространство ввода/вывода                                 |     |
| А.З. Аппаратные прерывания                                     | . 1 |
| А.4. Прямой доступ к памяти и прямое управление                | 'n  |
| шиной                                                          |     |
| А.5. Обмен данными                                             |     |
| А.б. Распределение системных ресурсов                          |     |
| А.7. Спецификация PnP для шины ISA34                           | U   |

| Приложение Б. Элементы цифровой схемотехники      | 353 |
|---------------------------------------------------|-----|
| Приложение В. Конструктивные элементы интерфейсов | 361 |
| Приложение Г. Проблемы заземления                 | 367 |
| Список сокращений                                 | 374 |
| Алфавитный указатель                              | 385 |

## Предисловие

PnP для шины ISA.

Совсем недавно была закончена работа над книгой «Аппаратные средства IBM РС. Энциклопедия». То, что Жванецкий говорил по поводу ремонта, справедливо, пожалуй, и для любой книги по компьютерной тематике — работу над ней «нельзя завершить, а можно только прекратить», поскольку ее написание «не процесс, а состояние». Вскоре после того, как автора перестали подпускать к тексту «Энциклопедии» (иначе книга не вышла бы в свет), ему удалось раздобыть новый материал по интерфейсам, что послужило толчком для написания новой книги. Это уже вторая «дочерняя» книга, первая — «Процессоры Intel: от 8086 до Pentium II» на полгода опередила свою родительницу и имела успех у читателей. Здесь тоже чего-то больше, что-то дано глубже, чем в «Энциклопедии», но круг вопросов ограничен только аппаратными интерфейсами утилитарного назначения. Книга адресована широкому кругу читателей, так или иначе связанных в своей деятельности с компьютерами. Знание различных интерфейсов позволяет разработчику аппаратуры выбирать вариант, адекватный решаемой задаче. Тому, кто занят не разработкой устройств, а их интеграцией, знание некоторых подробностей об интерфейсах тоже поможет в выборе изделий. Они, например, получат ответ на вопрос, почему и когда за SCSI нужно платить больше денег, чем за АТА/АТАРІ. Сведения, приведенные в этой книге, пригодятся и программистам-системщикам, которым приходится разрабатывать собственные драйверы периферийных устройств или залезать в чужие творения. Любознательные читатели смогут из книги почерпнуть много интересных подробностей «из жизни интерфейсов», например, почему так

Для удобства восприятия в книге принята система текстовых выделений. *Курсивом* выделены ключевые слова (например, первый раз встречающиеся определения), а также на-

хорошо (или плохо, нужное подчеркнуть) работает система

пример инструкций INT 2, или имен регистров (MSR). Для тех, кому «электрические детали» покажутся не совсем понятными, рекомендую обратиться за помощью к приложениям, в которых приведены некоторые сведения по системотехнике РС. Нет возможности изложить все нюансы интерфейсов — тогда книга оказалась бы или слишком толстой, или узко специализированной. Интернет дает возможность добраться до многих спецификаций и статей — спасибо коллективу RUSNet

звания состояний, в которых могут пребывать некоторые объекты. Названия электрических сигналов, например IRQ2, можно отличить от категорий, близких программистам, на-

(http://www.neva.ru). За время работы над книгой была собрана немалая коллекция документов, открытых для доступа (правда, большинство из них на английском языке). В систематизированном виде (как файлы HTML) эта коллекция (или ссылка на нее) будет помещена на сервере издательства «Питер» http://www.piter-press.ru.

Связаться с автором можно по электронной

mgook@stu.neva.ru.

## Введение

ет понятие *интерфейс* (*interface*) как границу раздела двух систем, устройств или программ; элементы соединения и вспомогательные схемы управления, используемые для соединения устройств. Эта книга посвящена интерфейсам, позволяющим подключать к персональным (и не только) компьютерам разнообразные периферийные устройства (ПУ) и их контроллеры.

Толковый словарь по вычислительным системам определя-

По способу передачи информации интерфейсы подразделяются на параллельные и последовательные. В параллельном интерфейсе все биты передаваемого слова (обычно байта) выставляются и передаются по соответствующим параллельно идущим проводам одновременно. В РС традиционно используется параллельный интерфейс Centronics, реализуемый LPT-портами. В последовательном интерфейсе биты передаются друг за другом, обычно по одной линии. СОМ-порты РС обеспечивают последовательный интерфейс в соответ-

ствии со стандартом RS-232C.

При рассмотрении интерфейсов важным параметром является пропускная способность. Технический прогресс приводит к неуклонному росту объемов передаваемой информации. Если раньше матричные принтеры, печатающие в символьном режиме, могли обходиться и СОМ-портом с невысокой пропускной способностью, то современным лазерным принтерам при высоком разрешении не хватает и производительности самых быстрых LPT-портов. То же касается и сканеров. А передача «живого» видео, даже с применением компрессии, требует немыслимой ранее пропускной способности.

Вполне очевидно, что при одинаковых быстродействии приемопередающих цепей и пропускной способности соединительных линий по скорости передачи параллельный интерфейс должен превосходить последовательный. Однако

ными вследствие неидентичности проводов и контактов разъемов. Для надежной передачи данных временные диаграммы обмена строятся с учетом возможного разброса времени прохождения сигналов, что является одним из факторов, сдерживающих рост пропускной способности параллельных интерфейсов. В последовательных интерфейсах, конечно же, есть свои проблемы повышения производительности, но, поскольку в них используется меньшее число линий (в пределе — одна), повышение пропускной способности линий связи обходится дешевле. Может, кто-нибудь еще помнит интерфейс канала ЕС ЭВМ (два пучка коаксиальных кабелей толщиной в руку) и видел кабель USB — эти интерфейсы (параллельный и последовательный) имеют примерно одинаковую пропускную способность.

повышение производительности за счет увеличения тактовой частоты передачи данных упирается в волновые свойства соединительных кабелей. В случае параллельного интерфейса начинают сказываться задержки сигналов при их прохождении по линиям кабеля, и, что самое неприятное, задержки в разных линиях интерфейса могут быть различ-

Для интерфейса, соединяющего (физически или логически) два устройства, различают три возможных режима обмена дуплексный, полудуплексный и симплексный. *Дуплексный* режим позволяет по одному каналу связи одновременно передавать информацию в обоих направлениях. Он может быть асимметричным, если пропускная способность в направлениях «туда» и «обратно» имеет существенно различающиеся значения, или симметричным. Полудуплексный режим позволяет передавать информацию «туда» и «обратно» по-

очередно, при этом интерфейс имеет средства переключения направления канала. Симплексный (односторонний) режим предусматривает только одно направление передачи информации (во встречном направлении передаются только вспомогательные сигналы интерфейса).

Другим немаловажным параметром интерфейса является допустимое удаление соединяемых устройств. Оно ограни-

чивается как частотными свойствами кабелей, так и помехозащищенностью интерфейсов. Часть помех возникает от соседних линий интерфейса - это перекрестные помехи, искажением уровней сигналов.
С появлением шин USB и FireWire в качестве характеристики интерфейса стала фигурировать и топология соедине-

защитой от которых может быть применение витых пар проводов для каждой линии. Другая часть помех вызывается

ния. Для интерфейсов RS-232C и Centronics практически всегда применялась двухточечная топология PC — устройство (или PC — PC). Исключениями из этого правила являются различные устройства безопасности и защиты данных (Security devices), которые подключаются к COM- или LPT-

портам, но имеют разъем для подключения внешнего уст-

ройства. Но поскольку эти устройства для традиционной периферии прозрачны, можно считать, что они не нарушают общего правила. Аналогично обстоит дело и с адаптерами локальных сетей (например, Paraport) и внешних дисковых накопителей (Iomega Zip), подключаемых к LPT-портам.

Хотя разрабатываемые стандарты для параллельного порта (IEEE 1284.3) и предусматривают соединение устройств в

цепочку (Daisy Chain) или через мультиплексоры, широкого распространения такие способы подключения пока не получили. К другому классу исключений относится построение моноканала на СОМ-портах, которое несколько лет назад применялось в «любительских» локальных сетях, но было вытеснено существенно более эффективной и подешевевшей технологией Ethernet. Интерфейсные шины USB и

FireWire реализуют древовидную топологию, в которой внеш-

ние устройства могут быть как оконечными, так и промежуточными (разветвителями). Эта топология позволяет подключать множество устройств к одному порту USB или FireWire.

Важным свойством интерфейса, на которое часто не обращают внимания, является гальваническая развязка, а точнее —

щают внимания, является *гальваническая развязка*, а точнее — ее *отсутствие*. «Схемные земли» устройств, соединяемых интерфейсом с СОМ- или LPT-портом PC, оказываются свя-

занными со схемной землей компьютера (а через интерфейсный кабель и между собой). Если между ними до подключения интерфейса была разность потенциалов, то по общему

проводу интерфейса потечет уравнивающий ток, что плохо по целому ряду причин. Падение напряжения на общем про-

интерфейсов гальваническую развязку устройств обеспечивают только MIDI (одностороннюю с напряжением изоляции до 100 В) и шина FireWire (полную с напряжением изоляции до 500 В).

Внутренние интерфейсы

Вышеприведенные рассуждения относились в основном к внешним интерфейсам — соединяющим отдельные устрой-

ства, удаленные друг от друга на заметное расстояние. Но интерес представляют и *внутренние* интерфейсы, предназначенные для быстрой связи на короткие расстояния. Стандартизованные *шины расширения ввода/вывода* обеспечива-

воде, вызванное протеканием этого тока, приводит к смещению уровней сигналов, а протекание переменного тока приводит к сложению полезного сигнала с переменной составляющей помехи. К этим помехам особенно чувствительны ТТЛ-интерфейсы; в то же время в RS-232C смещение и помеху в пределах 2 В поглотит зона нечувствительности. В случае обрыва общего провода или плохого контакта, а гораздо чаще — при подключении и отключении интерфейсов без выключения питания устройств разность потенциалов прикладывается к сигнальным цепям, а протекание уравнивающих токов через них часто приводит к пиротехническим эффектам. Откуда берется эта разность потенциалов, объяснить нетрудно (см. приложение Г). Из рассматриваемых

ют расширяемость РС, который никогда не замыкался на выполнении сугубо вычислительных задач. Эти шины предоставляют более широкие возможности для взаимодействия процессора с аппаратурой, не скованные жесткими ограничениями внешних интерфейсов. Шины расширения ввода/вывода реализуются в виде слотов (щелевых разъемов) на системной плате компьютера. К ним относятся:

- ISA-8 и ISA-16 традиционные универсальные слоты подключения периферийных адаптеров, не требующих высоких скоростей обмена (раньше ISA была единственной шиной расширения).
- ЕISA дорогая (по стоимости и системной платы, и плат расширения) 32-битная шина средней производительности, применяемая в основном для подключения контрол-

меняется в серверах, где необходимо установить множество плат расширения (системную плату, у которой слотов РСІ больше, чем 4, найти довольно трудно, а для шины EISA 6–8 слотов — явление обычное).

MCA — шина компьютеров PS/2, до сих пор применяемая и в некоторых серверах. Производительность — сред-

леров дисков и адаптеров локальных сетей в серверах. В настоящее время вытесняется шиной PCI, хотя и при-

няя. Адаптеры для шины МСА не получили широкого распространения.

VLB — быстродействующая 32- или 64-битная локальная

шина процессора, применявшаяся в среднем поколении системных плат для процессора 486. Используется для подключения контроллеров дисков, графических адаптеров и контроллеров локальных сетей в паре со слотом ISA/EISA. С процессорами последующих поколений не применяется.

РСІ — самая распространенная высокопроизводительная 32/64-битная шина, применяемая в компьютерах на процессорах 486 и старше, а также на «неинтеловских» платформах. Используется для подключения адаптеров дисков, контроллеров SCSI, графических, коммуникаци-

онных и других адаптеров. На системной плате чаще всего устанавливают 3 или 4 слота РСІ.

АGP — магистральный интерфейс подключения интеллектуальных графических адаптеров, применяемый в новых системных платах для процессоров шестого поколения

системных платах для процессоров шестого поколения.

РС Card, он же PCMCIA — слот расширения блокнотных компьютеров, который в принципе может присутствовать и в компьютерах настольного исполнения (встречать на практике не доводилось). Предназначен для

ствовать и в компьютерах настольного исполнения (встречать на практике не доводилось). Предназначен для подключения периферии к блокнотным РС.

За универсальность и производительность внутренних шин

За универсальность и производительность внутренних шин расширения приходится расплачиваться более замысловатой реализацией интерфейсных схем и сложностями при обеспечении совместимости с другим установленным в компью-

тер оборудованием. Здесь ошибки могут приводить к потере (хорошо, если временной) работоспособности компьютера. сертифицированных (ими или независимыми лабораториями) карт расширения. При использовании внешних интерфейсов неприятности в случае ошибок чаще всего имеют отношение только к подключаемому устройству. Хотя и здесь случаются всякие «чудеса», часть из которых описана в при-

Своеобразное положение занимает шина SCSI — интерфейсная шина системного уровня, предназначенная для подклю-

ложении Г.

Недаром серьезные производители компьютеров гарантируют работоспособность своих изделий только при установке

чения широкого спектра ПУ, требующих высокой скорости обмена данными. Конструктивно эта шина реализуется ленточным кабелем-шлейфом, соединяющим внутренние и внешние устройства с хост-адаптером компьютера. По функциональным возможностям и производительности за этой шиной «гонится» похожая по конструкции шина АТА, которая из специализированного интерфейса дисковых накопителей выросла до вполне универсального интерфейса АТАРІ, логически родственного SCSI. Однако, в отличие от

похоже, не догнать. На этом мы закончим краткий обзор интерфейсов и перейдем к их детальному описанию.

SCSI, ATA конструктивно является сугубо внутренней, а по функциональным возможностям (количеству подключаемых устройств, обеспечению многозадачности) шину SCSI ей,

## 1. Параллельные интерфейсы

Параллельные интерфейсы характеризуются тем, что в них для передачи бит в слове используются отдельные сигнальные линии, и биты передаются одновременно. Параллельные интерфейсы используют логические уровни ТТЛ (транзистор-

интерфеисы используют логические уровни 11Л (транзисторно-транзисторной логики), что ограничивает длину кабеля изза невысокой помехозащищенности ТТЛ-интерфейса. Гальваническая развязка отсутствует. Параллельные интерфейсы

используют для подключения принтеров. Передача данных может быть как однонаправленной (*Centronics*), так и двунаправленной (*Bitronics*). Иногда параллельный интерфейс используют для связи между двумя компьютерами — получается сеть, «сделанная на коленке» (LapLink). Ниже будут рассмотрены протоколы интерфейсов *Centronics*, стандарт IEEE 1284, а также реализующие их порты PC.

#### I.1. Интерфейс Centronics и LPT-порт

строчные принтеры, название «LPT» осталось.

Для подключения принтера по интерфейсу *Centronics* в РС был введен *порт параллельного интерфейса* — так возникло название *LPT*-порт (Line PrinTer — построчный принтер). Хотя сейчас через этот порт подключаются не только по-

#### 1.1.1. Интерфейс Centronics

Понятие *Centronics* относится как к набору сигналов и протоколу взаимодействия, так и к 36-контактному разъему на принтерах. Назначение сигналов приведено в табл. 1.1, а временные диаграммы обмена с принтером — на рис. 1.1.

Интерфейс *Centronics* поддерживается принтерами с параллельным интерфейсом. Его отечественным аналогом является интерфейс *ИРПР-М*.

Традиционный порт *SPP* (Standard Parallel Port) является однонаправленным портом, через который программно реализуется протокол обмена *Centronics*. Порт вырабатывает

| аппаратное прерывание по импульсу на входе Ack#. Сигналы порта выводятся на разъем DB-25S (розетка), установленный непосредственно на плате адаптера (или системной плате) или соединяемый с ней плоским шлейфом. Название и назначение сигналов разъема порта (табл. 1.2) соответствуют интерфейсу Centronics.  Табляца 1.1. Сагналы интерфейса Centronics |          |           |                                                                                                                                                                                                  |  |  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------|-----------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Сигнал                                                                                                                                                                                                                                                                                                                                                      | I/0*     | Контакт   | Назначение                                                                                                                                                                                       |  |  |
| Strobe#                                                                                                                                                                                                                                                                                                                                                     | I        | 1         | Строб данных. Данные фиксируются по низкому уровию сигнала                                                                                                                                       |  |  |
| Data [0:7]                                                                                                                                                                                                                                                                                                                                                  | I        | 2-9       | Линии данных. Data 0 (контакт 2) — младший бит                                                                                                                                                   |  |  |
| Ack#                                                                                                                                                                                                                                                                                                                                                        | О        | 10        | Acknowledge — импульс подтверж-<br>дения приема байта (запрос на<br>прием следующего). Может исполь-<br>зоваться для формирования<br>запроса прерывания                                          |  |  |
| Busy                                                                                                                                                                                                                                                                                                                                                        | О        | 11        | Занято. Прием данных возможен только при низком уровне сигнала                                                                                                                                   |  |  |
| PaperEnd                                                                                                                                                                                                                                                                                                                                                    | О        | 12        | Высокий уровень сигнализирует о конце бумаги                                                                                                                                                     |  |  |
| Select                                                                                                                                                                                                                                                                                                                                                      | О        | 13        | Сигнализирует о включении прин-<br>тера (обычно в принтере соединя-<br>ется резистором с цепью +5 В)                                                                                             |  |  |
| Auto LF#                                                                                                                                                                                                                                                                                                                                                    | I        | 14        | Автоматический перевод строки. При низком уровне принтер, получив символ <i>CR</i> (Carriage Return — возврат каретки), автоматически выполняет и функцию <i>LF</i> (Line Feed — перевод строки) |  |  |
| Error#                                                                                                                                                                                                                                                                                                                                                      | 0        | 32        | Ошибка: конец бумаги, состояние<br>OFF-Line или впутренняя ошибка<br>принтера                                                                                                                    |  |  |
| lnit#                                                                                                                                                                                                                                                                                                                                                       | I        | 31        | Инициализация (сброс в режим<br>параметров умолчания, возврат<br>к началу строки)                                                                                                                |  |  |
| Select In#                                                                                                                                                                                                                                                                                                                                                  | I        | 36        | Выбор принтера (низким уровнем). При высоком уровне принтер не воспринимает остальные сигналы интерфейса                                                                                         |  |  |
| GND                                                                                                                                                                                                                                                                                                                                                         | <u> </u> | 19-30, 33 | Общий провод интерфейса                                                                                                                                                                          |  |  |



Рис. 1.1. Передача данных по протоколу Centronics

#### Таблица 1.2. Разъем стандартного LPT-порта

| Контакт<br>DB-25S | Номер<br>провода                         | Назначение |            |            |
|-------------------|------------------------------------------|------------|------------|------------|
|                   | в кабеле                                 | I/0*       | Reg. Bit** | Сигнал     |
| 1                 | 1                                        | O/I        | CR.0\      | Strobe#    |
| 2                 | 3                                        | O(1)       | DR.0       | Data 0     |
| 3                 | 5                                        | O(I)       | DR.1       | Data 1     |
| 4                 | 7                                        | O(I)       | DR.2       | Data 2     |
| 5                 | 9                                        | O(I)       | DR.3       | Data 3     |
| 6                 | 11                                       | O(I)       | DR.4       | Data 4     |
| 7                 | 13                                       | O(I)       | DR.5       | Data 5     |
| 8                 | 15                                       | O(I)       | DR.6       | Data 6 .   |
| 9                 | 17                                       | O(I)       | DR.7       | Data 7     |
| 10                | 19                                       | [***       | SR.6       | Ack#       |
| 11                | 21                                       | ı          | SR.7∖      | Busy       |
| 12                | 23                                       | l l        | SR.5       | PaperEnd   |
| 13                | 25                                       | · ·        | SR.4       | Select     |
| 14                | 2                                        | O/I        | CR.1\      | Auto LF#   |
| 15                | 4                                        | I          | SR,3       | Error#     |
| 16                | 6                                        | 0/1        | CR.2       | lnit#      |
| 17                | 8                                        | 0/1        | CR.3∖      | Select In# |
| 18—25             | 10, 12, 14,<br>16, 18, 20,<br>22, 24, 26 |            | -          | -          |

<sup>\*</sup> I/O задает направление передачи (вход/выход) сигнала порта. O/I обозначает выходные линии, состояние которых считывается при чтении из портов вывода; (I) — выходные линии, состояние которых может быть считано только при особых условиях (см. ниже).

<sup>\*\*</sup> Символом «\» отмечены инвертированные сигналы (1 в регистре соответствует низкому уровню линии).

<sup>\*\*\*</sup> Вход Аск# соединен резистором (10 кОм) с питанием +5 В.

#### 1.1.2. Традиционный LPT-порт

бор регистров, расположенных в пространстве ввода/вывода. Регистры порта адресуются относительно базового адреса порта, стандартными значениями которого являются 3ВСh, 378h и 278h. Порт может использовать линию запроса аппаратного прерывания, обычно IRQ7 или IRQ5. Порт имеет внешнюю 8-битную шину данных, 5-битную шину сигналов состояния и 4-битную шину управляющих сигналов. BIOS поддерживает до четырех (иногда до трех) LPT-портов (LPT1-LPT4) своим сервисом — прерыванием INT 17h, обеспечивающим через них связь с принтером по интерфейсу Centronics. Этим сервисом BIOS осуществляет вывод символа (по опросу готовности, не используя аппаратных прерываний), инициализацию интерфейса и принтера, а также опрос состояния принтера. Стандартный порт имеет три 8-битных регистра, расположенных по соседним адресам в пространстве ввода/вывода,

Адаптер параллельного интерфейса представляет собой на-

начиная с базового адреса порта (BASE).

Data Register (DR) — регистр данных, адрес=BASE. Данные, записанные в этот порт, выводятся на выходные линии интерфейса. Данные, считанные из этого регистра, в зависимости от схемотехники адаптера соответствуют либо ранее записанным данным, либо сигналам на тех же линиях, что не всегда одно и то же. Если в порт записать байт с единицами

всетда одно и то же. Если в порт записать оаит с единицами во всех разрядах, а на выходные линии интерфейса через микросхемы с выходом типа «открытый коллектор» подать какой-либо код (или соединить ключами какие-то линии со схемной землей), то этот код может быть считан из того же регистра данных. Таким образом на многих старых моделях адаптеров можно реализовать порт ввода дискретных сигналов, однако выходным цепям передатчика информации придется «бороться» с выходным током логической единицы выходных буферов адаптера. Схемотехника ТТЛ такие решения не запрещает, но если внешнее устройство выполнено на микросхемах КМОП, их мощности может не хватить для «победы» в этом шинном конфликте. Однако современ-

такой способ ввода не будет работать на всех компьютерах. На некоторых адаптерах портов выходной буфер отключается перемычкой на плате. Тогда порт превращается в обыкновенный порт ввода.

Status Register (SR) — регистр состояния; представляет собой 5-битный порт ввода сигналов состояния принтера (биты

ные адаптеры часто имеют в выходной цепи согласующий резистор с сопротивлением до 50 Ом. Выходной ток короткого замыкания выхода на землю обычно не превышает 30 мА. Простой расчет показывает, что в случае короткого замыкания контакта разъема на землю при выводе «единицы» на этом резисторе падает напряжение 1,5 В, что входной схемой приемника будет воспринято как «единица». Так что

Busy (11): при низком уровне на линии устанавливается единичное значения бита — разрешение на вывод очередного байта.

SR.6 — Ack (Acknowledge) — отображения состояния ли-

- SR.6 Ack (Acknowledge) отображения состояния линии Ack# (10).
   SR.5 PE (Paper End) отображения состояния линии Paper End (12). Единичное значение соответствует высо-
- кому уровню линии сигналу о конце бумаги в принтере. \$\mathrm{SR.4 - Select}\$ — отображения состояния линии Select (13). Единичное значение соответствует высокому уровню линии — сигналу о включении принтера.
- SR.3 Error отображения состояния линии Error (15).
   Нулевое значение соответствует низкому уровню линии сигналу о любой ошибке принтера.
  - SR.2 PIRQ флаг прерывания по сигналу Ack# (только для порта PS/2). Бит обнуляется, если сигнал Ack# вызвал аппаратное прерывание. Единичное значение ус-

танавливается по аппаратному сбросу и после чтения регистра состояния.

Как и регистр данных, этот 4-битный порт вывода допускает запись и чтение (биты 0-3), но его выходной буфер обычно имеет тип «открытый коллектор». Это позволяет корректно использовать линии данного регистра как входные при программировании их в высокий уровень. Биты 0, 1, 3 инвер-

SR[1:0] — зарезервированы.
 Control Register (CR) — регистр управления, адрес=BASE+2.

тируются.

CR.5 — Direction — бит управления направлением передачи (только для портов PS/2). Запись единицы переводит порт данных в режим ввода. При чтении состояние бита не определено.
 CR.4 — AckintEn (Ack Interrupt Enable) — единичное значение разрешает прерывание по спаду сигнала на линии

*CR.3* — *Select In* — единичное значение бита соответствует низкому уровню на выходе *Select In#* (17) — сигналу, разрешающему работу принтера по интерфейсу *Centronics*. *CR.2* — *Init* — нулевое значение бита соответствует низко-

Ack# — сигнал запроса следующего байта.

му уровню на выходе *Init*# (16) — сигналу аппаратного сброса принтера. *CR.1* — *Auto LF* — единичное значение бита соответствует низкому уровню на выходе *Auto LF*# (14) — сигналу на автоматический перевод строки (*LF* — Line Feed) по при-

называют AutoFD или AutoFDXT.

« CR.0 — Strobe — единичное значение бита соответствует низкому уровню на выходе Strobe# (1) — сигналу стробирования выходных данных.

ему байта возврата каретки (CR). Иногда сигнал и бит

Запрос аппаратного прерывания (обычно IRQ7 или IRQ5) вырабатывается по отрицательному перепаду сигнала на выводе 10 разъема интерфейса (Ack#) при установке *CR.4*=1. Во

тором с шиной +5 В. Прерывание вырабатывается, когда принтер подтверждает прием предыдущего байта. Как уже было сказано, BIOS это прерывание не использует и не обслуживает.

Процедура вывода байта по интерфейсу *Centronics* включает

избежание ложных прерываний контакт 10 соединен резис-

следующие шаги (в скобках приведено требуемое количество шинных операций процессора):

Вывод байта в регистр данных (1 цикл ЮМР#).

Ввод из регистра состояния и проверка готовности уст-

\*

ройства (бит *SR*.7 — сигнал Busy). Этот шаг зацикливается до получения готовности или до срабатывания программного тайм-аута (минимум 1 цикл IORD#).

граммного тайм-аута (минимум 1 цикл IORD#).

■ По получении готовности выводом в регистр управления устанавливается строб данных, а следующим выводом строб снимается (2 цикла IOWR#). Обычно, чтобы переключить

только один бит (строб), регистр управления предварительно считывается, что добавляет еще один цикл IORD#. Видно, что для вывода одного байта требуется 4–5 операций ввода/вывода с регистрами порта (в лучшем случае, когда готовность обнаружена по первому чтению регистра состояния). Отсюда вытекает главный недостаток вывода через

готовность оонаружена по первому чтению регистра состояния). Отсюда вытекает главный недостаток вывода через стандартный порт — невысокая скорость обмена при значительной загрузке процессора. Порт удается разогнать до скоростей 100–150 Кбайт/с при полной загрузке процессора, что недостаточно для печати на лазерном принтере. Другой недостаток — функциональный — сложность использования в канестре порта врода

качестве порта ввода.

Стандартный порт асимметричен — при наличии 12 линий (и бит), нормально работающих на вывод, на ввод работают только 5 линий состояния. Если необходима симметричная двунаправленная связь, на всех стандартных портах работоспособен режим полубайтного обмена — Nibble Mode. В этом

тоспособен режим полубайтного обмена — Nibble Mode. В этом режиме, называемом также Hewlett Packard Bitronics, одновременно передаются 4 бита данных, пятая линия используется для квитирования. Таким образом, каждый байт передается за два цикла, а каждый цикл требует по крайней

мере 5 операций ввода/вывода.

#### 1.1.3. Расширения параллельного порта

Недостатки стандартного порта частично устраняли новые типы портов, появившиеся в компьютерах PS/2.

Двунаправленный порт 1 (Type 1 parallel port) — интерфейс, введенный в PS/2. Такой порт кроме стандартного режима может работать в режиме ввода или двунаправленном ре-

жиме. Протокол обмена формируется программно, а для указания направления передачи в регистр управления пор-

та введен специальный бит *CR.5*: 0 — буфер данных работает на вывод, 1 — на ввод. Не путайте этот порт, называемый также *enhanced bi-directional*, с EPP. Данный тип порта прижился и в обычных компьютерах.

Порт с прямым доступом к памяти (Type 3 DMA parallel port)

применялся в PS/2 моделей 57, 90, 95. Был введен для повышения пропускной способности и разгрузки процессора при выводе на принтер. Программе, работающей с портом, требовалось только задать в памяти блок данных, подлежащих выводу, а затем вывод по протоколу *Centronics* производился без участия процессора.

Позже появились другие адаптеры LPT-портов, реализующие протокол обмена *Centronics* аппаратно — *Fast Centronics*. Некоторые из них использовали FIFO-буфер данных — *Parallel Port FIFO Mode*. Не будучи стандартизованными, такие порты разных производителей требовали использования собственных специальных драйверов. Программы, использующие прямое управление регистрами стандартных портов, не умели более эффективно их использовать. Такие порты часто входили в состав мультикарт VLB. Существуют их ва-

рианты с шиной ISA, в том числе встроенные.

#### 1.2. Стандарт IEEE 1284

Стандарт на параллельный интерфейс *IEEE* 1284, принятый в 1994 году, определяет порты *SPP*, *EPP* и *ECP*. Стандарт определяет 5 режимов обмена данными, метод согласования режима, физический и электрический интерфейсы. Согласно IEEE 1284, возможны следующие режимы обмена данными через параллельный порт:

Полубайтный режим (Nibble Mode) — ввод байта в два цикла (по 4 бита), используя для приема линии состояния. Этот режим обмена может использоваться на любых адаптерах.
 Байтный режим (Byte Mode) — ввод байта целиком, используя для приема линии данных. Этот режим работает только на портах, допускающих чтение выходных дан-

Режим совместимости (Compatibility Mode) — однонаправленный (вывод) по протоколу Centronics. Этот режим со-

ответствует стандартному порту SPP.

ных (Bi-Directional или PS/2 Type 1).

Режим EPP (Enhanced Parallel Port) (EPP Mode) — двунаправленный обмен данными. Управляющие сигналы интерфейса генерируются аппаратно во время цикла обращения к порту. Эффективен при работе с устройства-

ми внешней памяти и адаптерами локальных сетей.

№ Режим ЕСР (Extended Capability Port) (ECP Mode) — двунаправленный обмен данными с возможностью аппаратного сжатия данных по методу RLE (Run Length Encoding) и использования FIFO-буферов и DMA. Управляющие сигналы интерфейса генерируются аппаратно. Эффективен для принтеров и сканеров.
В компьютерах с LPT-портом на системной плате режим —

SPP, EPP, ECP или их комбинация — задается в BIOS Setup. Режим совместимости полностью соответствует стандартно-

му порту SPP. Остальные режимы подробно рассмотрены ниже.

#### 1.2.1. Физический и электрический интерфейсы

Стандарт IEEE 1284 определяет физические характеристики приемников и передатчиков сигналов. Спецификации стандартного порта не задавали типов выходных схем, предельных значений величин нагрузочных резисторов и

емкости, вносимой цепями и проводниками. На относительно невысоких скоростях обмена разброс этих параметров не вызывал проблем совместимости. Однако расширенные (функционально и по скорости передачи) режимы

вень (Level II) определен для устройств, работающих в расширенных режимах, с высокими скоростями и длинными кабелями. К передатикам предъявляются следующие требования:
№ Уровни сигналов без нагрузки не должны выходить за пределы −0,5... +5,5 В.
№ Уровни сигналов при токе нагрузки 14 мА должны быть

требуют четких спецификаций. IEEE 1284 определяет два уровня интерфейсной совместимости. Первый уровень (Level I) определен для устройств медленных, но использующих смену направления передачи данных. Второй уро-

не ниже +2,4 В для высокого уровня (V<sub>OH</sub>) и не выше +0,4 В для низкого уровня (V<sub>OL</sub>) на постоянном токе.

Выходной импеданс R<sub>O</sub>, измеренный на разъеме, должен составлять 50±5 Ом на уровне V<sub>OH</sub>—V<sub>OL</sub>. Для обеспечения заданного импеданса используют последовательные резисторы в выходных цепях передатчика. Согласование им-

- торы в выходных цепях передатчика. Согласование импеданса передатчика и кабеля снижает уровень импульсных помех.

  Скорость нарастания (спада) импульса должна находиться в продолжу 0.05–0.4 В /из
- ся в пределах 0,05-0,4 В/нс. Требования к *приемпикам*:
- ※ Допустимые пиковые значения сигналов −2,0...+7,0 В.

   ※ Пороги срабатывания должны быть не выше 2,0 В (V<sub>II</sub>) для высокого уровня и не ниже 0,8 В (V<sub>II</sub>) для низкого.
- Приемник должен иметь гистерезис в пределах 0,2...1,2 В (гистерезисом обладают специальные микросхемы — триг-теры Шмитта).
- Входной ток микросхемы (втекающий и вытекающий) не должен превышать 20 мкА, входные линии соединяются с шиной питания +5. В резистором 1.2 кОм
- должен превышать 20 мкА, входные линии соединяются с шиной питания +5 В резистором 1,2 кОм.

  Входная емкость не должна превышать 50 пФ.
- Когда появилась спецификация ECP, фирма Microsoft рекомендовала применение динамических терминаторов на каждую линию интерфейса. Однако в настоящее время сле-

дуют спецификации IEEE 1284, в которой динамические

терминаторы не применяются. Рекомендованные схемы входных, выходных и двунаправленных цепей приведены на рис. 1.2.

Стандарт IEEE 1284 определяет три типа используемых разъемов. Типы A (DB-25) и B (Centronics-36) используются в традиционных кабелях подключения принтера, тип C —

новый малогабаритный 36-контактный разъем.



Рис. 1.2. Оконечные цепи линий интерфейса IEEE 1284:
 а — однонаправленных, б — двунаправленных
 Традиционные интерфейсные кабели имеют от 18 до 25 про-

водов, в зависимости от числа проводников цепи GND. Эти

проводники могут быть как перевитыми, так и нет. К экранированию кабеля жестких требований не предъявлялось. Такие кабели вряд ли будут надежно работать на скорости передачи 2 Мбайт/с и при длине более 2 м. Стандарт

передачи 2 моаит/с и при длине оолее IEEE 1284 регламентирует *свойства кабелей.* 

- Все сигнальные линии должны быть перевитыми с отдельными обратными (общими) проводами. Каждая пара должна иметь импеданс 62±6 Ом в частот-
- ном диапазоне 4-16 МГи. Уровень перекрестных помех между парами не должен
- превышать 10%. Кабель должен иметь экран (фольгу), покрывающий не
- менее 85% внешней поверхности. На концах кабеля экран должен быть окольцован и соединен с контактом разъема.

Кабели, удовлетворяющие этим требованиям, маркируются налписью «IEEE Std 1284-1994 Compliant». Они могут иметь

#### длину до 10 метров, обозначения типов приведены в табл. 1.3.

Таблица 1.3. Типы кабелей IEEE 1284

| Тип  | Расшифровка                                                     | Разъем 1  | Разъем 2    |
|------|-----------------------------------------------------------------|-----------|-------------|
| AMAM | Type A Male — Type A Male                                       | А (вилка) | А (вилка)   |
| AMAF | Type A Male — Type A Female                                     | А (вилка) | А (розетка) |
| AB   | Type A Male — Type B Plug<br>(стандартный кабель<br>к принтеру) | А (вилка) | В           |
| AC   | Type A Male — Type C Plug<br>(новый кабель к принтеру)          | А (вилка) | С           |
| BC   | Type B Plug — Type C Plug                                       | В         | С           |
| СС   | Type C Plug — Type C Plug                                       | С         | С           |

#### 1.2.2. Режимы передачи данных

## IEEE 1284 определяет пять режимов обмена, один из кото-

рых полностью соответствует стандартному выводу по протоколу Centronics. Стандарт определяет способ, по которому ПО может определить режим, доступный и хосту (РС), и

ПУ (или присоединенному второму компьютеру). Режимы нестандартных портов, реализующих протокол обмена Centronics аппаратно (Fast Centronics, Parallel Port FIFO Mode), могут и не являться режимами IEEE 1284, несмотря на наличие в них черт *EPP* и *ECP*.

При описании режимов обмена фигурируют следующие понятия:

- Хост компьютер, обладающий параллельным портом.
- MY- периферийное устройство, подключаемое к этому порту.
- Ptr в обозначениях сигналов обозначает передающее ПУ.
   Прямой канал канал вывода данных от хоста в ПУ.
- Моратный канал канал ввода данных в хост из ПУ.

#### Полубайтный режим ввода — Nibble Mode

Предназначен для двунаправленного обмена. Может работать на всех стандартных портах. Порты имеют 5 линий ввода состояния, используя которые ПУ может посылать в хост байт тетрадами (nibble — полубайт, 4 бита) за два приема. Сигнал Ack#, вызывающий прерывание, которое может использоваться в данном режиме, соответствует биту 6 регистра состояния, что усложняет программные манипуляции с битами при сборке байта. Сигналы порта приведены в табл. 1.4, временные диаграммы — на рис. 1.3.



Рис. 1.3. Прием данных в полубайтном режиме

Прием байта данных в полубайтном режиме состоит из следующих фаз:

- 1. Хост сигнализирует о готовности приема данных установкой низкого уровня на линии HostBusy.
- 2. ПУ в ответ помещает тетраду на входные линии состояния.

Хост устанавливает высокий уровень на линии HostBusy, указывая на занятость приемом и обработкой тетрады.
 ПУ отвечает установкой высокого уровня на линии PtrClk.

3. ПУ сигнализирует о готовности тетралы установкой низ-

кого уровня на линии PtrClk.

6. Шаги 1-5 повторяются для второй тетрады.

#### 6. Шаги 1-5 повторяются для второй тетрады.

Таблица 1.4. Сигналы LPT-порта в полубайтном режиме ввода

| Контакт | Сигнал SPP | I/0 | Описание                                                                                                                         |
|---------|------------|-----|----------------------------------------------------------------------------------------------------------------------------------|
| 14      | AutoFeed#  | 0   | HostBusy — сигнал квитирования.<br>Низкий уровень означает готовность к<br>приему тетрады, высокий подтверждает<br>прием тетрады |
| 17      | Selectin#  | 0   | Высокий уровень указывает на обмен<br>в режиме IEEE 1284 (в режиме SPP<br>уровень низкий)                                        |
| 10      | Ack#       | I   | PtrClk. Низкий уровень означает готовность тетрады, высокий— ответ на сигнал HostBusy                                            |
| 11      | Busy       | I   | Прием бита данных 3, затем бита 7                                                                                                |
| 12      | PE         | I   | Прием бита данных 2, затем бита 6                                                                                                |
| 13      | Select     | I   | Прием бита данных 1, затем бита 5                                                                                                |
|         |            |     |                                                                                                                                  |

Полубайтный режим сильно нагружает процессор, и поднять скорость обмена выше 50 Кбайт/с не удается. Безусловное его преимущество в том, что он работает на всех портах. Его применяют в тех случаях, когда поток данных невелик (например, для связи с принтерами). Однако при связи с адаптерами локальных сетей, внешними дисковыми накопителями и CD-ROM прием больших объемов данных требует изрядного терпения со стороны пользователя.

Прием бита данных 0, затем бита 4

#### Двунаправленный байтный режим — Byte Mode

15

Error#

В данном режиме данные принимаются с использованием двунаправленного порта, у которого выходной буфер дан-

дыдущие, режим является программно-управляемым — все сигналы квитирования анализируются и устанавливаются драйвером. Сигналы порта описаны в табл. 1.5, временные диаграммы — на рис. 1.4. Таблица: 1.5. Сигналы LPT-порта в байтном режиме ввода/вывода

I/O

O

O

Описание

Сигиал

Импульс (низкого уровня)

подтверждает прием байта в конце каждого цикла

Двунаправленный (прямой

и обратный) канал данных

квитирования.

ных может отключаться установкой бита СЯ.5=1. Как и пре-

в байтном режиме

HostClk

HostBusy

имя

Контакт

1

14

2-9

Data [0:7]

Сигнал SPP

Strobe#

AutoFeed#

|    |           |             |   | Низкий уровень означает готовность хоста принять байт; высокий уровень устанавливается по приему байта                                                 |
|----|-----------|-------------|---|--------------------------------------------------------------------------------------------------------------------------------------------------------|
| 17 | Selectin# | 1284Active  | 0 | Высокий уровень указывает на обмен в режиме IEEE 1284 (в режиме SPP уровень низкий)                                                                    |
| 16 | Init#     | Init#       | О | Не используется; установ-<br>лен высокий уровень                                                                                                       |
| 10 | Ack#      | PtrClk      | Ī | Устанавливается в низкий уровень для индикации действительности данных на линиях Data [0:7]. Низкий уровень устанавливается в ответ на сигнал HostBusy |
| 11 | Busy      | PtrBusy     | I | Состояние занятости пря-                                                                                                                               |
| 12 | PE        | AckDataReq* | I | Устанавливается ПУ для<br>указания на наличие обрат-<br>ного канала передачи                                                                           |
| 13 | Select    | Xflag*      | I | Флаг расширяемости                                                                                                                                     |
| 15 | Error#    | DataAvail#* | I | Устанавливается ПУ для<br>указания на наличие обрат-<br>ного канала передачи                                                                           |

Сигналы действуют в последовательности согласования (см. далее).

Data [0:7]



Рис. 1.4. Прием данных в байтном режиме

#### Фазы приема байта данных:

- 1. Хост сигнализирует о готовности приема данных установкой низкого уровня на линии HostBusy.
- 2. ПУ в ответ помещает байт данных на линии Data [0:7].
- 3. ПУ сигнализирует о действительности байта установкой низкого уровня на линии PtrClk.
- 4. Хост устанавливает высокий уровень на линии HostBusy, указывая на занятость приемом и обработкой байта.
- 5. ПУ отвечает установкой высокого уровня на линии PtrClk.
- 6. Хост подтверждает прием байта импульсом HostClk.7. Шаги 1-6 повторяются для каждого следующего байта.
- Побайтный режим позволяет поднять скорость обратного канала до скорости прямого канала в стандартном режиме. Однако он может работать только на двунаправленных портах.

#### Режим ЕРР

Протокол *EPP* (Enhanced Parallel Port — улучшенный параллельный порт) был разработан компаниями Intel, Xircom и Zenith Data Systems задолго до принятия IEEE 1284. Он предназначен для повышения производительности обмена по параллельному порту. *EPP* был реализован в чипсете Intel 386SL (микросхема 82360) и впоследствии принят множеством компаний как дополнительный протокол параллельного порта. Версии протокола, реализованные до принятия IEEE 1284, отличаются от нынешнего стандарта (см. далее).

Протокол ЕРР обеспечивает четыре типа циклов обмена: запись данных:

чтение данных:

запись адреса; 88

Контакт

14

17

16

10

11

2-9

12

13

15

33

чтение адреса.

Сигнал SPP

Strobe#

AutoLF#

Selectin#

Init#

Ack#

Busy

Data [0:7]

**PaperEnd** 

Select

Error#

Назначение циклов записи и чтения данных очевидно. Ал-

Имя в ЕРР

Write#

DataStb#

AddrSth#

Reset#

INTR#

Wait#

AD[0:7]

Xflag\*

AckDataReg\*

DataAvail#\*

ресные циклы используются для передачи адресной, канальной и управляющей информации. Циклы обмена данными

отличаются от адресных циклов применяемыми стробирую-

щими сигналами. Назначение сигналов порта ЕРР и их связь с сигналами SPP объясняются в табл. 1.6.

I/O

O

O

O

O

Ī

Ŧ

1/0

Ŧ

Ŧ

Ī

\* Сигналы действуют в последовательности согласования (см. далее).

Таблица 1.6. Сигналы СРТ-порта в режиме ввода/вывода ЕРР

уровень

высокий

данных.

в циклах передачи данных

Строб адреса. Низкий уро-

вень устанавливается в ад-

Сброс ПУ (низким уровнем)

Низкий уровень разрешает

Используется по усмотрению

Используется по усмотрению

разработчика периферии Используется по усмотрению

разработчика периферии

разработчика периферии

цикла строба в низкий уровень), переход в высокий —

решает завершение

(снятие строба)

адреса / данных

Двунаправленная

цикл

цикл

Низкий устанавливается

квитирования.

(установку

раз-

цикла

шина

Описание

Низкий

записи.

чтения

Строб

уровень

Сигнал

начало

ресных циклах

Прерывание от ПУ

*EPP*-порт имеет *расширенный набор регистров* (табл. 1.7), который занимает в пространстве ввода/вывода 5-8 смежных байт.

Режим

SPP/EPP

R/W

Описание

Регистр данных SPP

троллерах могут исполь-

16-/

операций

зоваться

32-битных

ввода/вывода

#### Таблица 1.7. Регистры ЕРР-порта

Смещение

Имя регистра

SPP Data Port

| 011 2 000 1 000     | l "  | 1011/211 | 1 '' | I concomp common of t                                                                                             |
|---------------------|------|----------|------|-------------------------------------------------------------------------------------------------------------------|
| SPP Status Port     | +1   | SPP/EPP  | R    | Регистр состояния SPP                                                                                             |
| SPP Control Port    | +2   | SPP/EPP  | w    | Регистр управления SPP                                                                                            |
| EPP Address<br>Port | +3   | EPP      | R/W  | Регистр адреса ЕРР.<br>Чтение или запись в<br>него генерирует связан-<br>ный цикл чтения или<br>записи адреса ЕРР |
| EPP Data Port       | +4   | EPP      | R/W  | Регистр дапных ЕРР.<br>Чтение (запись) генерирует связанный цикл<br>чтения (записи) данных ЕРР                    |
| Not Defined         | +5+7 | EPP      | N/A  | В некоторых кон-                                                                                                  |

В отличие от программно-управляемых режимов, описанных ранее, внешние сигналы *EPP*-порта для каждого цикла обмена формируются аппаратно по одной операции записи или чтения в регистр порта. На рис. 1.5 приведена диаграмма *цик*-

ла записи данных, иллюстрирующая внешний цикл обмена, вложенный в цикл записи системной шины процессора (иногда эти циклы называют связанными). Адресный цикл записи отличается от цикла данных только стробом внешнего ин-

терфейса.

Цикл записи данных состоит из следующих фаз:

1. Программа выполняет цикл вывода (IOWR#) в порт 4 (EPP)

Data Port).2. Адаптер устанавливает сигнал Write# (низкий уровень), и данные помещаются на выходную шину LPT-порта.

6. Завершается процессорный цикл вывода. 7. ПУ устанавливает низкий уровень Wait#, указывая на возможность начала следующего цикла.

При низком уровне Wait# устанавливается строб данных. 4. Порт ждет подтверждения от ПУ (перевода Wait# в вы-

Снимается строб данных — внешний ЕРР-цикл завер-

3.

5.

сокий уровень).

шается.

IOW# Write# Data Strobe# Wait# Data [0:7] Действительные данные

Рис. 1.5. Цикл записи данных ЕРР

Пример адресного *цикла чтения* приведен на рис. 1.6. Цикл



Рис. 1.6. Адресный цикл чтения ЕРР

Главной отличительной чертой ЕРР является выполнение внешней передачи во время одного процессорного цикла ввоки настраиваться на скорость обмена, доступную и хосту, и ПУ. ПУ может регулировать длительность всех фаз обмена с помощью всего лишь одного сигнала Wait#. Протокол автоматически подстраивается под длину кабеля — вносимые задержки приведут только к удлинению цикла. Поскольку кабели, соответствующие IEEE 1284 (см. выше), имеют одинаковые волновые свойства для разных линий, нарушения передачи, связанного с «состязаниями» сигналов, происходить не должно. При подключении сетевых адаптеров или внешних дисков к *EPP*-порту можно наблюдать непривычное явление: снижение производительности по мере удлинения интерфейсного кабеля.

да/вывода. Это позволяет достигать высоких скоростей обмена (0,5...2 Мбайт/с). ПУ, подключенное к параллельному порту *EPP*, может работать со скоростью устройства, подключаемого через слот ISA. Протокол блокированного квитирования (interlocked handshakes) позволяет автоматичествения (interlocked handshakes)

Естественно, ПУ не должно «подвешивать» процессор на шинном цикле обмена. Это гарантирует механизм тайм-аутов РС, который принудительно завершает любой цикл обмена, длящийся более 15 мкс. В ряде реализаций *EPP* за тайм-аутом интерфейса следит сам адаптер — если ПУ не отвечает в течение определенного времени (5 мкс), цикл прекращается и в дополнительном (не стандартизованном) регистре состояния адаптера фиксируется ошибка.

Устройства с интерфейсом *EPP*, разработанные до принятия IEEE 1284, отличаются началом цикла: строб DataStb# или

Это означает, что ПУ не может задержать начало следующего цикла (хотя может растянуть его на требуемое время). Такая спецификация называется *EPP 1.7* (предложена Xircom). Именно она применялась в контроллере 82360. Периферия, совместимая с *EPP 1.7*, будет нормально работать и с контроллером *EPP 1284*, но периферия в стандарте

AddrStb# устанавливается независимо от состояния WAIT#.

*EPP 1284* может отказаться работать с контроллером *EPP 1.7*. С *программной* точки зрения контроллер *EPP*-порта выглядит просто (см. табл. 1.7). К трем регистрам стандартного порта, имеющим смещение 0, 1 и 2 относительно базового

адреса порта, добавлены два регистра (EPP Address Port и EPP Data Port), чтение и запись в которые вызывает генерацию связанных внешних циклов. Назначение регистров стандартного порта сохранено для со-

вместимости ЕРР-порта с ПУ и ПО, рассчитанными на применение программно-управляемого обмена. Поскольку сигналы квитирования адаптером вырабатываются аппаратно,

при записи в регистр управления СР биты 0, 1 и 3, соответствующие сигналам Strobe#, AutoFeed# и SelectIn#, должны иметь нулевые значения. Программное вмешательство могло бы нарушить последовательность квитирования. Некоторые адаптеры имеют специальные средства защиты (ЕРР

Protect), при включении которых программная модификация этих бит блокируется. Использование регистра данных ЕРР позволяет осуществлять передачу блока данных с помощью одной инструкции REP INSB или REP OUTSB. Некоторые адаптеры допускают 16-/

32-битное обращение к регистру данных ЕРР. При этом адап-

тер просто дешифрует адрес со смещением в диапазоне 4-7 как адрес регистра данных ЕРР, но процессору сообщает о разрядности 8 бит. Тогда 16- или 32-битное обращение по адресу регистра данных ЕРР приведет к автоматической генерации двух или четырех шинных циклов по нарастающим адресам, начиная со смещения 4. Эти циклы будут выполняться быстрее, чем то же количество одиночных циклов. Таким образом обеспечивается производительность до

шних дисков, стриммеров и CD-ROM. Адресные циклы EPP всегда выполняются только в однобайтном режиме. Важной чертой ЕРР является то, что обращение процессора

2 Мбайт/с, достаточная для адаптеров локальных сетей, вне-

к ПУ осуществляется в реальном времени — нет буферизации. Драйвер способен отслеживать состояние и подавать

команды в точно известные моменты времени. Циклы чтения и записи могут чередоваться в произвольном порядке или идти блоками. Такой тип обмена удобен для регистроориентированных ПУ или ПУ, работающих в реальном времени, — сетевых адаптеров, устройств сбора информации и

управления и т. п.

#### Режим ЕСР

и Microsoft для связи с ПУ типа принтеров или сканеров. Как и *EPP*, данный протокол обеспечивает высокопроизводительный двунаправленный обмен данными хоста с ПУ.

Протокол *ECP* (Extended Capability Port — порт с расширенными возможностями) был предложен Hewlett Packard

Протокол *ECP* в обоих направлениях обеспечивает два типа пиклов:

- щиклы записи и чтения данных;
- ₩ командные циклы записи и чтения.

канальных адресов и передачу счетчика *RLC* (Run-Length Count).
В отличие от *EPP*, вместе с протоколом *ECP* сразу появился

Командные циклы подразделяются на два типа: передачу

стандарт на программную (регистровую) модель его адаптера, изложенный в документе «The IEEE 1284 Extended Capabilities Port Protocol and ISA Interface Standard» компании Microsoft. Этот документ определяет свойства протокола, не заданные стандартом IEEE 1284:

- ж компрессию данных хост-адаптером по методу RLE;
- \* буферизацию FIFO для прямого и обратного каналов;

Компрессия в реальном времени по методу *RLE* (Run-Length Encoding) позволяет достичь коэффициента сжатия 64:1 при передаче растровых изображений, которые имеют длинные

» применение DMA и программного ввода/вывода.

строки повторяющихся байт. Компрессию можно использовать, только если ее поддерживает и хост, и ПУ. Канальная адресация ЕСР применяется для адресации мно-

жества логических устройств, входящих в одно физическое. Например, в комбинированном устройстве факс/принтер/модем, подключаемом только к одному параллельному порту, возможен одновременный прием факса и печать на принтере. В режиме *SPP*, если принтер установит сигнал занятос-

ти, канал будет занят данными, пока принтер их не примет. В режиме *ECP* программный драйвер просто адресуется к другому *погическому каналу* того же порта.

Протокол *ECP* переопределяет сигналы *SPP* (табл. 1.8).

#### Таблица 1.8. Сигналы LPT-порта в режиме ввода/вывода ЕСР

| Контакт | Сигная SPP | Имя в ЕСР       | I/0 | Описание                                                                                                                                    |
|---------|------------|-----------------|-----|---------------------------------------------------------------------------------------------------------------------------------------------|
| 1       | Strobe#    | HostClk         | Ο   | Используется в паре<br>с PeriphAck для передачи<br>в прямом направлении<br>(вывод)                                                          |
| 14      | AutoLF#    | HostAck         | O   | Указывает тип цикла (команда/данные) при передаче в прямом направлении. Используется в паре с PeriphClk для передачи в обратном направлении |
| 17      | SelectIn#  | 1284Active      | 0   | Высокий уровень указывает на обмен в режиме IEEE 1284 (в режиме SPP уровень низкий)                                                         |
| 16      | Init#      | ReverseRequest# | 0   | Низкий уровень пере-<br>ключает канал на пере-<br>дачу в обратном направ-<br>лении                                                          |
| 10      | Ack#       | PeriphClk       | I   | Используется в паре<br>с HostAck для передачи<br>в обратном направлении                                                                     |

|    |          |             |   | дачу в обратном направ-<br>лении                                                                                                     |
|----|----------|-------------|---|--------------------------------------------------------------------------------------------------------------------------------------|
| 10 | Ack#     | PeriphClk   | I | Используется в паре<br>с HostAck для передачи<br>в обратном направлении                                                              |
| 11 | Busy     | PeriphAck   | I | Используется в паре с HostClk для передачи в обратном направлении. Индицирует тип команда/данные при передаче в обратном направлении |
| 12 | PaperEnd | AckReverse# | I | Переводится в низкий                                                                                                                 |

уровень как подтверж-

дение сигналу ReverseRequest#

Xflag\* 13 ī Флаг расширяемости 15 Frror# Устанавливается ПУ для PeriphRequest#\* I указания на доступность (наличие) обратного канала передачи\* Data [0:7] Data [0:7] 2-9 Двунаправленный канал I/O ланных

Select

<sup>\*</sup> Сигналы действуют в последовательности согласования (см. далее).

налы квитирования аппаратно, но его работа существенно отличается от режима ЕРР. На рис. 1.7а приведена диаграмма двух циклов прямой передачи: за циклом данных следует командный цикл. *Тип шикла* задается уровнем на линии HostAck: в цикле данных — вы-

сокий, в командном цикле — низкий. В командном цикле байт может содержать канальный адрес или счетчик RLE. Отли-

Адаптер ЕСР тоже генерирует внешние протокольные сиг-

чительным признаком является бит 7 (старший): если он нулевой, то биты 0-6 содержат счетчик RLE (0-127), если единичный — то канальный адрес. На рис. 1.76 показана пара циклов обратной передачи. HostClk PeriphAck Data[0:7] Байт 0 HostAck Данные Команда



В отличие от диаграмм обмена ЕРР, на рис. 1.7 не приведены сигналы циклов системной шины процессора. В данном

тельно независимых процесса, которые связаны через FIFOбуфер. Обмен драйвера с FIFO-буфером может осуществляться с использованием как DMA, так и программного

режиме обмен программы с ПУ разбивается на два относи-

Хост помещает данные на шину канала и устанавливает признак цикла данных (высокий уровень) или команды (низкий уровень) на линии HostAck.
 Хост устанавливает низкий уровень на линии HostClk, указывая на действительность данных.

3. ПУ отвечает установкой высокого уровня на линии

PeriphAck.

ввода-вывода. Обмен ПУ с буфером аппаратно выполняет адаптер *ECP*. Драйвер в режиме *ECP* не имеет информации о точном состоянии процесса обмена, но здесь обычно важно только то, завершен он или нет. *Прямая передача* данных на внешнем интерфейсе состоит из следующих шагов:

Хост устанавливает высокий уровень линии HostClk, и этот перепад может использоваться для фиксации данных в ПУ.
 ПУ устанавливает низкий уровень на линии PeriphAck для указания на готовность к приему следующего байта.

Поскольку передача в *ECP* происходит через FIFO-буферы, которые могут присутствовать на обеих сторонах интерфейса, важно понимать, на каком этапе данные можно считать переданными. Данные считаются *переданными* на шаге 4, когда линия HostClk переходит в высокий уровень. В этот

момент модифицируются счетчики переданных и принятых байт. В протоколе *ECP* есть условия, вызывающие прекращение обмена между шагами 3 и 4. Тогда эти данные не должны рассматриваться как переданные.
Из рис. 1.7 видно и другое отличие *ECP* от *EPP*. Протокол

Из рис. 1.7 видно и другое отличие *ECP* от *EPP*. Протокол *EPP* позволяет драйверу чередовать циклы прямой и обратной передачи, не запрашивая подтверждения на смену направления. В *ECP смена направления* должна быть согласована: хост запрашивает реверс установкой ReverseRequest#, после чего он должен дождаться подтверждения сигналом

AckReverse#. Поскольку предыдущий цикл мог выполняться по прямому доступу, драйвер должен дождаться завершения прямого доступа или прервать его, выгрузить буфер FIFO, определив точное значение счетчика переданных байт,

и только после этого запрашивать реверс.

1. Хост запрашивает изменение направления канала, устанавливая низкий уровень на линии ReverseRequest#. ПУ разрешает смену направления установкой низкого

Обратная передача данных состоит из следующих шагов:

уровня на линии AckReverse#.

признак цикла данных (высокий уровень) или команды (низкий уровень) на линии PeriphAck. ПУ устанавливает низкий уровень на линии PeriphClk, указывая на действительность данных.

ПУ помещает данные на шину канала и устанавливает

- 5. Хост отвечает установкой высокого уровня на линии HostAck. ПУ устанавливает высокий уровень линии PeriphClk; этот 6. перепад может использоваться для фиксации данных хос-
- 7. Хост устанавливает низкий уровень на линии HostAck для указания на готовность к приему следующего байта. Режимы и регистры ЕСР-порта Программный интерфейс и регистры ЕСР для адаптеров

TOM.

IEEE 1284 определяет спецификация Microsoft. Определены режимы (табл. 1.9), в которых может функционировать адаптер. Они задаются полем *Mode* регистра *ECR* (биты [7:5]).

Регистровая модель адаптера ЕСР (табл. 1.10) использует свойства архитектуры стандартной шины и адаптеров ISA для дешифрации адресов портов ввода/вывода задействуются

только 10 младших линий шины адреса. Поэтому, например, обращения по адресам Port, Port+400h, Port+800h... будут восприниматься как обращения к адресу Port, лежащему в диапазоне 0-3FFh. Современные РС и адаптеры декодируют

большее количество адресных бит, поэтому обращения по адресам 0378h и 0778h будет адресованы двум различным регистрам. Помещение дополнительных регистров *ECP* «за спину» регистров стандартного порта (смещение 400-402h) преследует две цели. Во-первых, эти адреса никогда не ис-

пользовались традиционными адаптерами и их драйверами, и их применение в ЕСР не приведет к сужению доступного не режимов 000-001 и возможность определения присутствия *ECP*-адаптера через попытку обращения к его расширенным регистрам.

адресного пространства ввода/вывода. Во-вторых, этим обеспечивается совместимость со старыми адаптерами на уров-

Табляца 1.9. Режины ЕСР-порта Режим Название

Зарезервировано

101

000SPP modeСтандартный (традиционный) режим001Bi-directional modeДвунаправленный порт (тип 1 для PS/2)010Fast CentronicsОднонаправленный с использованием<br/>FIFO и DMA

Описание

 011
 ECP Parallel Port mode
 ECP

 100
 EPP Parallel Port mode\*
 Перевод в режим EPP

110 Test mode Тестирование работы FIFO и прерываний
111 Configuration mode Доступ к конфигурационным регистрам

\* Этот режим не входит в спецификацию Microsoft, но трактуется как EPP контроллером SMC FDC37C665/666 и многими другими.

Каждому режиму *ECP* соответствуют (и доступны) свои

функциональные регистры. Переключение режимов осуществляется записью в регистр *ECR*. «Дежурными» режимами, включаемыми по умолчанию, являются 000 или 001. В любом из них работает полубайтный режим ввода. Из этих режимов всегла можно переключиться в любой другой, но из

бом из них работает полубайтный режим ввода. Из этих режимов всегда можно переключиться в любой другой, но из старших режимов (010–111) переключение возможно только в 000 или 001. Для корректной работы интерфейса перед выходом из старших режимов необходимо дождаться завершения обмена по прямому доступу и очистки FIFO-буфера.

В *режиме 000 (SPP)* порт работает как стандартный однонаправленный программно-управляемый *SPP*. В *режиме 001 (Ві-Dі PS/2)* порт работает как двунаправлен-

В режиме 001 (Bi-Di PS/2) порт работает как двунаправленный порт PS/2 типа 1. От режима 000 отличается возможностью реверса канала данных по биту CR.5.

вырабатываются аппаратно. Сигнал запроса прерывания вырабатывается по состоянию FIFO-буфера, но не по сигналу Ack# (запрос одиночного байта «не интересует» драйвер быстрого блочного вывода).

Режим 011 является собственно режимом ECP, описанным ранее. Поток данных и команд, передаваемых в ПУ, помещается в FIFO-буфер через регистры ECPDFIFO и ECPAFIFO соответственно. Из FIFO они выводятся с соответствующим

признаком цикла (состояние линии HostAck). Принимаемый поток данных от ПУ извлекается из FIFO-буфера через регистр *ECPDFIFO*. Получение адреса в командном цикле от

Режим 010 (Fast Centronics) предназначен только для высокопроизводительного вывода через FIFO-буфер с использованием DMA. Сигналы квитирования по протоколу Centronics

ПУ не предусматривается. Обмен с регистром *ECPDFIFO* может производиться и по каналу DMA.

Компрессия по методу RLE при передаче выполняется программно. Для передачи подряд более двух одинаковых байт данных в регистр *ECPAFIFO* записывается байт, у которого младшие 7 бит содержат счетчик RLC (значение RLC=127 соответствует 128 повторам), а старший бит нулевой. После этого в *ECPDFIFO* записывается сам байт. Отсюда очевидно, что вывод данных с одновременным использованием компрессии и DMA невозможен. Принимая эту пару байт (командный байт и байт данных), ПУ осуществляет декомпрессию. При приеме потока от ПУ адаптер *ECP* декомпрессию

осуществляет аппаратно и в FIFO-буфер помещает уже декомпрессированные данные. Режим 100 (EPP) — один из способов включения режима EPP. Режим 110 (Test Mode) предназначен для тестирования взаимодействия FIFO и прерываний. Данные могут переда-

модействия FIFO и прерываний. Данные могут передаваться в/из регистра *TFIFO* с помощью DMA или программным способом. На внешний интерфейс обмен не воздействует. Адаптер отрабатывает операции вхолостую на максимальной скорости интерфейса (как будто сигналы

квитирования приходят без задержек). Адаптер следит за состоянием буфера и по мере необходимости вырабатывает сигналы запроса прерывания. Таким образом программа

канала. Режим 111 (Configuration mode) предназначен для доступа к конфигурационным регистрам. Выделение режима зашишает адаптер и протокол от некорректных изменений конфигурации в процессе обмена.

может определить максимальную пропускную способность

## Таблица 1.10, Регистры ЕСР

| Смещение Имя R/W Режимы ЕСР* Название |          | Название |         |                           |
|---------------------------------------|----------|----------|---------|---------------------------|
| 000                                   | DR       | R/W      | 000-001 | Data Register             |
| 000                                   | ECPAFIFO | R/W      | 011     | ECP Address FIFO          |
| 001                                   | SR       | R/W      | Bce     | Status Register           |
| 002                                   | CR       | R/W      | Bce     | Control Register          |
| 400                                   | SDFIFO   | R/W      | 010     | Parallel Port Data FIFO   |
| 400                                   | ECPDFIFO | R/W      | 011     | ECP Data FIFO             |
| 400                                   | TFIFO    | R/W      | 110     | Test FIFO                 |
| 400                                   | CNFGA    | R        | 111     | Configuration Register A  |
| 401                                   | CNFGB    | R/W      | 111     | Configuration Register B  |
| 402                                   | ECR      | R/W      | Bce     | Extended Control Register |

<sup>\*</sup> Регистры доступны только в указанных режимах (режим задается битами 7-5 регистра ECR).

Регистр данных DR используется для передачи данных только в программно-управляемых режимах (000 и 001).

Регистр состояния SR передает значение сигналов на соответствующих линиях (как в SPP).

Регистр управления CR имеет назначение бит, совпадающее с SPP. В режимах 010, 011 запись в биты 0, 1 (сигналы

AutoLF# и Strobe#) игнорируется. Регистр ECPAFIFO служит для помещения информации ко-

мандных циклов (канального адреса или счетчика RLE, в зависимости от бита 7) в FIFO-буфер. Из буфера информа-

ция будет выдана в командном цикле вывода.

рез буфер FIFO по протоколу ЕСР. Perucmp TFIFO обеспечивает механизм тестирования FIFOбуфера в режиме 110. Регистр ECPCFGA позволяет считывать информацию об адаптере (идентификационный код в битах [7:4]. *Регистр ЕСРСГGВ* хранит информацию, необходимую драйверу. Запись в регистр не влияет на работу порта.

Perucmp SDFIFO используется для передачи данных в режиме 010. Данные, записанные в регистр (или посланные по каналу DMA), передаются через буфер FIFO по реализованному аппаратно протоколу Centronics. При этом должно быть задано прямое направление передачи (бит СЯ.5=0). Регистр DFIFO используется для обмена данными в режиме 011 (ЕСР). Данные, записанные в регистр или считанные из него (или переданные по каналу DMA), передаются че-

- **Назначение бит регистра** *ECR*:
  - ECR[7:5] ECP MODE задает режим ECP.

  - ECR.4 ERRINTREN# (Error Interrupt Disable) запреща-

*Регистр ЕСР* — главный управляющий регистр *ЕСР*.

- ет прерывания по сигналу Error# (при нулевом значении бита по отрицательному перепаду на этой линии выра-
- батывается запрос прерывания).
- **ECR.3 DMAEN** (DMA Enable) разрешает обмен по ка-
- налу DMA.
- ECR.2 SERVICENTR (Service Interrupt) запрещает сер-
- висные прерывания, которые вырабатываются по окончании цикла DMA (если он разрешен), по порогу заполнения/опустошения FIFO-буфера (если не используется
- DMA) и по ошибке переполнения буфера сверху или снизу. ECR. 1 — FIFOFS (FIFO Full Status) — сигнализирует о заполнении буфера; при FIFOFS=1 в буфере нет ни одно-
- го свободного байта. ECR.0 — FIFOES (FIFO Empty Status) — указывает на полное опустошение буфера; комбинация FIFOFS=FIFOES=1

или снизу).

означает ошибку работы с FIFO (переполнение сверху

ется совместимость драйвера со старыми адаптерами и старых драйверов с новыми адаптерами.
По интерфейсу с программой *ECP*-порт напоминает *EPP*: после установки режима (записи кода в регистр *ECR*) обмен данными с устройством сводится к чтению или записи в со-

Когда порт находится в стандартном или двунаправленном режимах (000 или 001), первые три регистра полностью совпадают с регистрами стандартного порта. Так обеспечива-

блюдают либо по регистру *ECR*, либо по обслуживанию сервисных прерываний от порта. Весь протокол квитирования генерируется адаптером аппаратно. Обмен данными с *ECP*-портом (кроме явного программного) возможен и по прямому доступу к памяти (каналу DMA), что эффективно при передаче больших блоков данных.

ответствующие регистры. За состоянием FIFO-буфера на-

## **1.2.3. Согласование режимов IEEE 1284**ПУ в стандарте IEEE 1284 обычно не требуют от контроллера

реализации всех режимов, предусмотренных стандартом. Для определения режимов и методов управления конкретным устройством стандарт предусматривает последовательность согласования (negotiation sequence). Последовательность построена так, что старые устройства, не рассчитанные на при-

согласования (negotiation sequence). Последовательность построена так, что старые устройства, не рассчитанные на применение IEEE 1284, на нее не ответят, и контроллер останется в стандартном режиме. Периферия IEEE 1284 может сообщить о своих возможностях, и контроллер установит режим, удовлетворяющий и хост, и ПУ.

сообщить о своих возможностях, и контроллер установит режим, удовлетворяющий и хост, и ПУ. Во время фазы согласования контроллер выставляет на линии данных байт расширяемости (extensibility byte), запрашивая подтверждение на перевод интерфейса в требуемый режим или прием идентификатора ПУ (табл. 1.11). Иден-

тификатор передается контроллеру в запрошенном режиме (любой режим обратного канала, кроме *EPP*). ПУ использует сигнал Xflag (Select в терминах *SPP*) для подтверждения запрошенного режима обратного канала, кроме полубайтного. Полубайтный режим поддерживается всеми устройствами IEEE 1284. Бит *Extensibility Link request* послужит для

определения дополнительных режимов в будущих расшире-

ниях стандарта.

#### Таблица 1.11. Биты в байте расширяемости

Описание

AutoLF#.

Бит

|      |                                                      | комбинации<br>бит [7:0] |
|------|------------------------------------------------------|-------------------------|
| 7    | Request Extensibility Link — зарсзервирован          | 1000 0000               |
| 6    | Запрос режима ЕРР                                    | 0100 0000               |
| 5    | Запрос режима ECP с RLE                              | 0011 0000               |
| 4    | Запрос режима <i>ЕСР</i> без RLE                     | 0001 0000               |
| 3    | Зарезервировано                                      | 0000 1000               |
| 2    | Запрос идентификатора устройства с ответом в режиме: |                         |
|      | полубайтный                                          | 0000 0100               |
|      | байтный                                              | 0000 0101               |
|      | ECP 6e3 RLE                                          | 0001 0100               |
|      | ECP c RLE                                            | 0011 0100               |
| 1    | Зарезервировано                                      | 0000 0010               |
| 0    | Запрос полубайтного режима                           | 0000 0001               |
| none | Запрос байтного режима                               | 0000 0000               |

Допустимые

## Последовательность согласования (рис. 1.8) состоит из следующих шагов:

- 1. Хост выводит байт расширяемости на линии данных.
- Хост устанавливает высокий уровень сигнала Selectln# и низкий AutoFeed#, что означает начало последовательности согласования.
   ПУ отвечает установкой низкого уровня сигнала Ack# и высокого Error#, PaperEnd и Select. Устройство, «не по-
- нимающее» стандарта 1284, ответа не даст, и дальнейшие шаги не выполнятся.

  4. Хост устанавливает низкий уровень сигнала Strobe# для
- Аост устанавливает низкии уровень сигнала Strobe# для записи байта расширяемости в ПУ.
   Хост устанавливает высокий уровень сигналов Strobe# и

ния, после чего контроллер устанавливает требуемый режим работы. Selectin#

7. ПУ устанавливает высокий уровень на линии Аск# для указания на завершение последовательности согласова-

6. ПУ отвечает установкой в низкий уровень сигналов PaperEnd и Error#, если ПУ имеет обратный канал передачи данных. Если запрошенный режим поддерживается устройством, на линии Select устанавливается высокий

уровень, если не поддерживается — низкий.

AutoFeed# Байт расширяемост Data [0:7] Strobe# Error# /////// Select ////

Рис. 1.8. Последовательность согласования режимов IEEE 1284

## 1.2.4. Развитие стандарта IEEE 1284

Кроме основного стандарта ІЕЕЕ 1284, который уже принят, в настоящее время в стадии проработки находятся но-

вые стандарты, дополняющие его. К ним относятся: IEEE P1284.1 «Standard for Information Technology for Transport Independent Printer/Scanner Interface (TIP/SI)».

живания сканеров и принтеров на основе протокола NPAP (Network Printing Alliance Protocol).

Этот стандарт разрабатывается для управления и обслу-

IEEE P1284.2 «Standard for Test, Measurement and Conformance to IEEE Std. 1284» — стандарт для тестиро-

- вания портов, кабелей и устройств на совместимость с IEEE 1284.

  \*\* IEEE P1284.3 «Standard for Interface and Protocol Extensions
- to IEEE Std. 1284 Compliant Peripheral and Host Adapter Ports» стандарт на драйверы и использование устройств прикладным программным обеспечением (ПО). Уже приняты спецификации BIOS для использования *EPP* драйверами DOS. Прорабатывается стандарт на разделяемое использование одного порта цепочкой устройств или группой устройств, подключаемых через мультиплексор.

IEEE P1284.4 «Standard for Data Delivery and Logical Channels for IEEE Std. 1284 Interfaces» направлен на реализацию пакетного протокола достоверной передачи данных через параллельный порт. Основой служит протокол MLC (Multiple Logical Channels) фирмы Hewlett-Packard, однако совместимость с ним в окончательной версии стандарта не гарантируется.

# и **LPT-портов**Параллельные интерфейсы применяются в компьютерах раз-

параллельные интерфеисы применяются в компьютерах разных семейств и классов, здесь мы ограничимся рассмотрением IBM PC-совместимых компьютеров.

#### 1.3.1. Использование параллельных интерфейсов

1.3. Применение параллельных интерфейсов

Распространенным применением LPT-порта является подключение принтера и плоттера. Остановимся на аппаратных аспектах — режиме порта и кабеле подключения. Практически все принтеры могут работать с портом в режиме *SPP*, но применение расширенных режимов дает свои преимущества:

- Двунаправленный режим (Bi-Di) не повышает производительность, но служит для сообщения о состоянии и параметрах принтера.
- Скоростные режимы (Fast Centronics) повышают производительность принтера, но могут потребовать качественного кабеля (см. далее). От принтера не требуется каких-либо дополнительных «интеллектуальных» способностей.

которых принтерах реализован не полностью (может отсутствовать аппаратная компрессия). ЕСР поддерживают принтеры HP Desklet моделей 6xx, Laserlet 4 и далее, современные модели фирмы Lexmark. Требует применения кабеля, по частотным свойствам соответствующего IEEE 1284. Простейший вариант кабеля подключения принтера — 18-проводный кабель с неперевитыми проводами. Он используется для работы в режиме SPP. При длине более 2 м желательно, чтобы хотя бы линии Strobe# и Busy были перевиты с отдельными общими проводами. Для скоростных режимов может оказаться непригодным, причем сбои могут происходить нерегулярно и лишь при определенных последовательностях передаваемых кодов. Встречаются кабели Centronics, у которых отсутствует связь контакта 17 разъема РС с контактом 36 разъема принтера. При попытке подключения таким кабелем принтера, работающего в стандарте 1284, появится сообщение о необходимости применения «двунаправленного кабеля». Принтер не может сообщить системе о поддержке расширенных режимов, на что рассчитывают драйверы принтера. Неплохие электрические свойства имеют ленточные кабели, у которых сигнальные цепи (управляющих сигналов) чередуются с общими проводами. Но их применение в качестве

Режим ECP — потенциально самый эффективный, имеет системную поддержку во всех версиях Windows. На не-

слоя изоляции, высокая уязвимость) и неэстетично (круглые кабели смотрятся лучше). Идеальным вариантом являются кабели, в которых все сигнальные линии перевиты с общими проводами и заключены в общий экран — то, что требует IEEE 1248. Такие кабели гарантированно работают на скоростях до 2 Мбайт/с, их ллина может лостигать 10 м

внешнего интерфейса непрактично (нет второго защитного

гарантированно работают на скоростях до 2 Моайт/с, их длина может достигать 10 м. В табл. 1.12 приводится распайка кабеля подключения принтера с разъемом X1 типа A (DB25-P) со стороны РС и X2

типа В (Centronics-36) или типа С (миниатюрный) со стороны принтера. Использование общих проводов (GND) зависит от качества кабеля (см. выше). В простейшем случае

| один провод ратного про разъемах тип табл. 1.12, гд РС типа А, разъеме тип дой сигналь разъема соот | д. Качественны<br>вода для кажд<br>на А и В для эт<br>де в скобках ук<br>которым соотт<br>а С обратный | е кабели требу<br>дой сигнально<br>гого недостато<br>сазаны номера<br>ветствуют обр<br>провод (GND)<br>гнальным конт<br>такты GND 19- | ПО объединяются в уют отдельного об-<br>й линии, однако в чно контактов (см контактов разъема атные провода). Е имеется для каж-<br>тактам 1–17 этого—35. |
|-----------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|
| X1, разъем<br>РС типа А                                                                             | Сигнал                                                                                                 | X2, разъем<br>PRN типа В                                                                                                              | X2, разъем<br>PRN типа С                                                                                                                                  |
| 1                                                                                                   | Strobe#                                                                                                | PKN TURA B                                                                                                                            | 15                                                                                                                                                        |
| 2                                                                                                   | Data0                                                                                                  | 2                                                                                                                                     | 6                                                                                                                                                         |
| 3                                                                                                   | Data1                                                                                                  | 3                                                                                                                                     | 7                                                                                                                                                         |
| 4                                                                                                   | Data2                                                                                                  | 4                                                                                                                                     | 8                                                                                                                                                         |
| 5                                                                                                   | Data3                                                                                                  | 5                                                                                                                                     | 9                                                                                                                                                         |
| 6                                                                                                   | Data4                                                                                                  | 6                                                                                                                                     | 10                                                                                                                                                        |
| 7                                                                                                   | Data5                                                                                                  | 7                                                                                                                                     | 11                                                                                                                                                        |
| 8                                                                                                   | Data6                                                                                                  | 8                                                                                                                                     | 12                                                                                                                                                        |
| 9                                                                                                   | Data7                                                                                                  | 9                                                                                                                                     | 13                                                                                                                                                        |
| 10                                                                                                  | Ack#                                                                                                   | 10                                                                                                                                    | 3                                                                                                                                                         |
| 11                                                                                                  | Busy                                                                                                   | 11                                                                                                                                    | 1                                                                                                                                                         |
| 12                                                                                                  | PaperEnd                                                                                               | 12                                                                                                                                    | 5                                                                                                                                                         |
| 13                                                                                                  | Select                                                                                                 | 13                                                                                                                                    | 2                                                                                                                                                         |
| 14                                                                                                  | Auto LF#                                                                                               | 14                                                                                                                                    | 17                                                                                                                                                        |
| 15                                                                                                  | Error#                                                                                                 | 32                                                                                                                                    | 4                                                                                                                                                         |
| 16                                                                                                  | Init#                                                                                                  | 31                                                                                                                                    | 14                                                                                                                                                        |
| 17                                                                                                  | Select In#                                                                                             | 36                                                                                                                                    | 16                                                                                                                                                        |
| 18                                                                                                  | GND (1)                                                                                                | 19                                                                                                                                    | 33                                                                                                                                                        |
| 19                                                                                                  | GND (2 3)                                                                                              | 20 21                                                                                                                                 | 24 25                                                                                                                                                     |
| 20                                                                                                  | GND (4 5)                                                                                              | 22 23                                                                                                                                 | 26 27                                                                                                                                                     |
| 21                                                                                                  | GND (67)                                                                                               | 24 25                                                                                                                                 | 28 29                                                                                                                                                     |
| 22                                                                                                  | GND (8 9)                                                                                              | 26 27                                                                                                                                 | 30 31                                                                                                                                                     |
| 23                                                                                                  | GND (11 15)                                                                                            | 29                                                                                                                                    | 19 22                                                                                                                                                     |
| 24                                                                                                  | GND (10 12 13)                                                                                         | 28                                                                                                                                    | 20 21 23                                                                                                                                                  |
| 25                                                                                                  | GND (14 16 17)                                                                                         | 30                                                                                                                                    | 32 34 35                                                                                                                                                  |
|                                                                                                     | <del></del>                                                                                            | <del></del>                                                                                                                           | <del></del>                                                                                                                                               |

 ™ Протокол квитирования несколько иной.

 ™ Ко всем входным линиям (на принтере) подключены пары согласующих резисторов: 220 Ом к питанию +5 В и 330 Ом к общему проводу. Это позволяет использовать длинные кабели, но перегружает большинство интерфейсных адап-

Ряд отечественных (и стран бывшего СЭВ) принтеров имеет интерфейс *ИРПР* (*IFSP* в документации на принтеры ROBOTRON). Он является близким родственником интер-

фейса Centronics, но со следующими отличиями:

Линии данных инвертированы.

каоели, но перегружает оольшинство интерфеисных адаптеров РС.

« Сигналы ошибки и конца бумаги отсутствуют.

Интерфейс ИРПР может быть программно реализован через обычный LPT-порт, но для устранения перегрузки вы-

ходных линий согласующие резисторы из принтера желательно удалить. Порт, перегруженный по выходу, может преподносить всякого рода сюрпризы (естественно, неприятные и трудно диагностируемые).

Для связи двух компьютеров по параллельному интерфейсу применяются различные кабели в зависимости от режимов

Для связи двух компьютеров по параллельному интерфейсу применяются различные кабели в зависимости от режимов используемых портов. Самый простой и медленный — полубайтный режим, работающий на всех портах. Для этого режима в кабеле достаточно иметь 10 сигнальных и один об-

щий провод. Распайка разъемов кабеля приведена в табл. 1.13. Связь двух РС данным кабелем поддерживается стандартным ПО типа Interlnk из MS-DOS или Norton Commander. Для машин PS/2 с двунаправленным портом фирма IBM выпускала переходное устройство в комплекте с программой Data Migration Facility. Переходник устанавливался на разъем LPT-

Migration Facility. Переходник устанавливался на разъем LPT-порта PS/2, а к его разъему X2 типа *Centronics* присоединялся обычный принтерный кабель, подключаемый к LPT-порту любого PC. Так предлагалось решить проблему переноса файлов со старых компьютеров, оснащенных 5" дисководами, на компьютеры PS/2 с дисководами 3,5". Распайка такого пере-

ходника приведена в табл. 1.14. Как видно, данный переходник нельзя использовать при связи через Interlnk или Norton Commander. Если обе соединяемые машины имеют двуна-

двунаправленную связь. По скорости обмена превосходит вышеописанное полубайтное соединение в 2 раза. Это соединение не соответствует двунаправленному режиму IEEE 1284.

правленные порты, переходник обеспечивает симметричную

| Таблица 1.13. Кас     |  | 88 88 6 |              |
|-----------------------|--|---------|--------------|
| I SUI HILLS 1.10. DOL |  |         | علىنىدللىنىك |

| X1,  | , разъем РС#1 | х2, разъем РС#2 |      |  |
|------|---------------|-----------------|------|--|
| Бит  | Контакт       | Контакт         | Бит  |  |
| DR.0 | 2             | 15              | SR.3 |  |
| DR.1 | 3             | 13              | SR.4 |  |
| DR.2 | 4             | 12              | SR.5 |  |
| DR.3 | 5             | 10              | SR.6 |  |
| DR.4 | 6             | 11              | SR.7 |  |
| SR.6 | 10            | 5               | DR.3 |  |
| SR.7 | 11            | 6               | DR.4 |  |
| SR.5 | 12            | 4               | DR.2 |  |
| SR.4 | 13            | 3               | DR.1 |  |
| SR.3 | 15            | 2               | DR.0 |  |
| GND  | 18-25         | 18-25           | GND  |  |

| 024.7        |                     |                      | 1 22              |
|--------------|---------------------|----------------------|-------------------|
| SR.3         | 15                  | 2                    | DR.0              |
| GND          | 18-25               | 18-25                | GND               |
| Разъемы 2    | X1 и X2 — DB25-     | Р (вилки).           |                   |
| Таблица 1.14 | . Переходник Data I | Migration для IBM PS | ¥2                |
|              | X1                  |                      | X2                |
| Контакт      | Бит                 | Бит                  | Контакт           |
| 1            | CR.0                | SR.6                 | 10                |
| 2            | DR.0                | DR.0                 | 2                 |
| 3            | DR.1                | DR.1                 | 3                 |
| 4            | DR.2                | DR.2                 | 4                 |
| 5            | DR.3                | DR.3                 | 5                 |
| 6            | DR.4                | DR.4                 | 6                 |
| 7            | DR.5                | DR.5                 | 7                 |
| 8            | DR.6                | DR.6                 | 8                 |
| 9            | DR.7                | DR.7                 | 9                 |
| 10           | SR.6                | CR.0                 | 1                 |
| 12           | SR.5                | CR.3                 | 36                |
| 17           | CR.3                | SR.5                 | 12                |
| 18-25        | GND                 | GND                  | 19-30, 33         |
| Разъемы Х    | 1 — DB25-P (вил     | ка), X2 — Centror    | исs-36 (розетка). |
|              |                     |                      |                   |

отличие от предыдущих таблиц, описывающих кабели для программно-управляемых режимов, в ней приведены имена сигналов, которые аппаратно генерируются адаптерами портов. Этот же кабель может использоваться и для связи в байтном режиме. Такая связь поддерживается Windows 95.

Высокоскоростная связь двух компьютеров может выполняться и в режиме *ECP* (режим *EPP* неудобен, поскольку требует синхронизации шинных циклов ввода/вывода двух компьютеров). В табл. 1.15 приведена распайка кабеля. В

Разъем Х1 Разъем Х2 Контакт Имя в ЕСР Имя в ЕСР Контакт HostClk PeriphClk 1 10

Теблица: 1.15. Кабель связи РС-РС в режиме ЕСР и байтном режиме

HostAck PeriphAck 14 11 1284Active PeriphRequest# 17 15 16 ReverseRequest# AckReverse# 12 PeriphClk 10 HostClk 1 PeriphAck 11 HostAck 14 AckReverse# ReverseRequest# 12 16 13 Xflag PeriphRequest# 15 1284Active 17 Data [0:7] Data [0:7] 2-9 2-9

что маловероятно).

Подключение сканера к LPT-порту эффективно, только если порт обеспечивает хотя бы двунаправленный режим (Ві-Ді), поскольку основной поток — ввод. Лучше использовать порт ЕСР, если этот режим поддерживается сканером (или ЕРР,

Подключение внешних накопителей (Iomega Zip Drive, CD-ROM и др.), адаптеров ЛВС и других симметричных устройств ввода/вывода имеет свою специфику. В режиме SPP наряду с замедлением работы устройства заметна принципиальная асимметрия этого режима: чтение данных проис-

ходит в два раза медленнее, чем (весьма небыстрая) запись. Применение двунаправленного режима (Bi-Di или PS/2) *Type 1*) устранит эту асимметрию — *скорости сравняются*.

Только перейдя на ЕРР, можно получить нормальную ско-

рость работы. В режиме *EPP* подключение к LPT-порту почти не уступает по скорости подключению через ISA-контроллер. Это справедливо и при подключении устройств со стандартным интерфейсом шин к LPT-портам через преобразователи интерфейсов (например, LPT — IDE, LPT — SCSI, LPT — PCMCIA).

В табл. 1.16 описано назначение выводов разъема LPT-порта в различных режимах и их соответствие битам регистров стандартного порта.

## Таблица 1.16. Назначение выводов разъема LPT-порта и бит регистров в режимах SPP, ECP и EPP

| Контакт | 1/0 | Бит*  | SPP        | ECP             | EPP      |
|---------|-----|-------|------------|-----------------|----------|
| 1       | O/I | CR.0\ | Strobe#    | HostClk         | Write#   |
| 2       | O/I | DR.0  | Data 0     | Data 0          | Data 0   |
| 3       | O/I | DR.1  | Data 1     | Data 1          | Data 1   |
| 4       | O/I | DR.2  | Data 2     | Data 2          | Data 2   |
| 5       | O/I | DR.3  | Data 3     | Data 3          | Data 3   |
| 6       | O/I | DR.4  | Data 4     | Data 4          | Data 4   |
| 7       | O/I | DR.5  | Data 5     | Data 5          | Data 5   |
| 8       | O/I | DR.6  | Data 6     | Data 6          | Data 6   |
| 9       | O/I | DR.7  | Data 7     | Data 7          | Data 7   |
| 10      | I   | SR.6  | Ack#       | PeriphClk       | INTR#    |
| 11      | 1   | SR.7∖ | Busy       | PeriphAck       | Wait#    |
| 12      | I   | SR.5  | PaperEnd   | AckReverse#     | **       |
| 13      | I   | SR.4  | Select     | Xflag           | _**      |
| 14      | O/I | CR.1\ | Auto LF#   | HostAck         | DataStb# |
| 15      | I   | SR.3  | Error#     | PeriphRequest#  | -**      |
| 16      | O/I | CR.2  | Init#      | ReverseRequest# | Reset#   |
| 17      | 0/I | CR3\  | Select In# | 1284Active      | AddrStb# |

<sup>\*</sup> Символом «\» отмечены инвертированные сигналы (1 в регистре соответствует низкому уровню линии).

#### 1.3.2. Конфигурирование LPT-портов

Управление параллельным портом разделяется на два этапа — *предварительное конфизурирование* (Setup) аппаратных средств

<sup>\*\* -</sup> означает «определяется пользователем».

чений, вызванных некорректными действиями программы. Конфигурирование LPT-порта зависит от его исполнения. Порт, расположенный на плате расширения (мультикарте), устанавливаемой в слот ISA или ISA+VLB, конфигурируется джамперами на самой плате. Порт на системной плате конфигурируется через BIOS Setup.

порта и *текущее* (оперативное) *переключение* режимов работы прикладным или системным ПО. Оперативное переключение возможно только в пределах режимов, разрешенных при конфигурировании. Этим обеспечивается возможность согласования аппаратуры с ПО и блокирования ложных переклю-

Конфигурированию подлежат следующие параметры: *Базовый адрес* — 3BCh, 378h или 278h. При инициализации BIOS проверяет наличие портов по адресам именно в этом

порядке и, соответственно, присваивает обнаруженным портам логические имена LPT1, LPT2, LPT3. Agpec 3BCh

имеет адаптер порта, расположенный на плате MDA или HGC. Большинство портов по умолчанию конфигурируются на адрес 378h и могут переключаться на 278h.

Используемая линия запроса прерывания: для LPT — IRQ7, для LPT2 — IRQ5. Традиционно прерывания от принтера не используются, и этот дефицитный ресурс можно сэкономить. Однако при использовании скоростных ре-

жимов *ECP* (или *Fast Centronics*) работа через прерывания может заметно повысить производительность и сни-

Использование канала DMA для режимов ECP и Fast Centronics — разрешение и номер канала DMA (по умолчанию — 3).
Режимы работы порта:

зить загрузку процессора.

- ленном программно-управляемом режиме.
- PS/2, он же Bi-Directional отличается от SPP возможностью реверса канала (установкой CR.5=1).
- ностью реверса канала (установкой *CR.5=1*). *Fast Centronics* аппаратное формирование протокола *Cen-*

tronics с использованием FIFO-буфера и, возможно, DMA.

- EPP в зависимости от использования регистров порт работает в режиме SPP или EPP. ECP по умолчанию включается в режим SPP или PS/2,
- <sup>™</sup> ЕСР по умолчанию включается в режим SPP или PS/2, записью в ECR может переводиться в любой режим ECP, но перевод в EPP записью в ECR кода 100 не гарантируется.

приводит к повышению быстродействия обмена с подключенными ПУ, а только дает возможность драйверу и ПУ установить оптимальный режим в пределах их «разумения». Большинство современных драйверов и приложений пытаются использовать эффективные режимы, так что «подрезать им крылья» установкой простых режимов без веских оснований не стоит.

Принтеры и сканеры могут пожелать режима *ECP*. Windows (3.x, 95 и NT) имеет системные драйверы для этого режима. В среде DOS печать через *ECP* поддерживается только специальным загружаемым драйвером.

Сетевые адаптеры, внешние диски и CD-ROM, подключаемые к параллельному порту, могут использовать режим EPP. Для этого режима специальный драйвер пока еще не применяется; использование EPP включается в драйвер самого подключаемого устройства.

Большинство современных ПУ, подключаемых к LPT-порту, поддерживает стандарт 1284 и PnP. Для поддержки этих функций компьютером с аппаратной точки зрения достаточно иметь контроллер интерфейса, поддерживающий стандарт 1284. Если подключаемое устройство поддерживает PnP, оно по протоколу согласования режимов 1284 способно «договориться» с портом о возможных режимах обмена. Подключенное устройство должно сообщить операционной системе (ОС) все необходимые сведения о себе — идентификатор производителя, модель и набор поддерживаемых команд. Более подробная информация может содержать идентификатор класса, подробное описание и идентификатор устрой-

портов появляется в таблице, выводимой BIOS на экран перед загрузкой ОС. Список можно посмотреть и с помощью тестовых программ или прямо в BIOS Data Area с помощью отладчика.

Если BIOS обнаруживает меньше портов, чем установлено физически, скорее всего, двум портам присвоен один адрес. При этом работоспособность ни одного из конфликтующих портов не гарантируется: они будут одновременно выводить

сигналы, но при чтении состояния конфликт на шине скорее всего приведет к искажению данных. Программное тестирование порта без диагностической заглушки (Loop Back) не покажет ошибок, поскольку при этом читаются данные выходных регистров, а они у всех конфликтующих (по отдельности исправных) портов совпадут. Именно такое тестирование производит BIOS при проверке на наличие портов. Разбираться с такой ситуацией следует, последовательно устанавливая порты и наблюдая за адресами, появляющи-

Тестирование параллельных портов разумно начинать с *проверки их наличия* в системе. Список адресов установленных

ства, с которым обеспечивается совместимость. В соответствии с принятой информацией ОС может предпринять действия по установке требуемого ПО для поддержки данного

1.3.3. Неисправности и тестирование параллельных

устройства.

мися в списке.

легче смириться, чем бороться.

портов

Если физически установлен только один порт, а BIOS его не обнаруживает, то либо порт отключен при конфигурировании, либо он вышел из строя (скорее всего из-за нарушений правил подключения). Иногда вам везет, и неисправность устраняется при «передергивании» платы в слоте — там возникают проблемы с контактами.

Наблюдаются и такие «чудеса» — при «теплой» перезагрузке DOS после Windows 95 порт не виден (и приложения не могут печатать из MS-DOS). Однако после повторной пере-

загрузки DOS порт оказывается на месте. С этим явлением

Тестирование портов с помощью диагностических программ позволяет проверить выходные регистры, а при использовании специальных заглушек — и входные линии. Поскольку количество выходных линий порта (12) и входных (5) различно, то полная проверка порта с помощью пассивной заглушки принципиально невозможна. Разные программы тестирования требуют применения разных заглушек (рис. 1.9).

| printerioristi puondi |    |          |  |  |  |
|-----------------------|----|----------|--|--|--|
| DB25P                 |    |          |  |  |  |
| Strobe#               | 1  | 4        |  |  |  |
| Select                | 13 | 4        |  |  |  |
| Data 0                | 2  | 4        |  |  |  |
| Error#                | 15 | €        |  |  |  |
| lnit#                 | 16 | <u></u>  |  |  |  |
| Ack#                  | 10 | <b>←</b> |  |  |  |
| Select In#            | 17 | 4        |  |  |  |
| Busy 11 <b>←</b>      |    |          |  |  |  |
| Auto LF#              | 14 | 4        |  |  |  |
| PaperEnd              | 12 | 4        |  |  |  |
|                       |    |          |  |  |  |

Рис. 1.9. Схема заглушки для тестирования LPT-порта программой Checklt

Большинство неприятностей при работе с LPT-портами доставляют разъемы и кабели. Для проверки порта, кабеля и принтера можно воспользоваться специальными тестами из популярных диагностических программ (CheckIt, PCCheck и т. п.), а можно и попытаться вывести на принтер какойлибо символьный файл.

- Если вывод файла с точки зрения DOS проходит (копирование файла на устройство с именем LPTn или PRN совершается быстро и успешно), а принтер (исправный) не напечатал ни одного символа скорее всего, это обрыв (неконтакт в разъеме) цепи Strobe#.
- Если принтер, подключенный к порту, в стандартном режиме (SPP) печатает нормально, а при переходе в ECP начинаются сбои, следует проверить кабель соответствует ли он требованиям IEEE 1284 (см. выше). Дешевые

ного кабеля», проверьте наличие связи контакта 17 разъема DB-25 с контактом 36 разъема Centronics. Хотя эта связь изначально предусматривалась, в ряде кабелей она отсутствует.

Всли принтер искажает информацию при печати, возможен обрыв (или замыкание) линий данных. В этом случае удобно воспользоваться файлом, содержащим последовательность кодов всех печатных символов. Вот пример

кабели с неперевитыми проводами нормально работают на скоростях 50–100 Кбайт/с, но при скорости 1–2 Мбайт/с, обеспечиваемой ЕСР, имеют полное право не

Если при установке драйвера PnP-принтера появилось сообщение о необходимости применения «двунаправлен-

работать, особенно при длине более 2 м.

программы на языке Basic:

20 FOR J=2 TO 15

10 OPEN "bincod.chr" FOR OUTPUT AS #1

30 FOR I=0 TO 15
40 PRINT#1, CHR\$(16\*J+I);
50 NEXT I
60 PRINT#1
70 NEXT J
80 CLOSE #1
90 END

Файл BINCOD. CHR, созданный данной программой, представляет собой таблицу всех печатных символов (управляющие коды пропущены), расположенных по 16 символов в строке. Если файл печатается с повтором некоторых символов или их групп, по периодичности повтора можно легко вычислить оборванный провод данных интерфейса. Этот же файл удобно использовать для проверки аппаратной русификации принтера.

Аппаратные прерывания от LPT-порта используются не всегда. Даже DOS-программа фоновой печати PRINT работает с портом по опросу состояния, а ее обслуживающий процесс запускается по прерыванию от таймера. Поэтому неисправности, связанные с цепью прерывания от порта, проявляют-

подключив к порту ПУ или заглушку. Если к порту с неисправным каналом прерывания подключить адаптер локальной сети, то он, возможно, будет работать, но с очень низкой скоростью: на любой запрос ответ будет приходить с задержкой в десятки секунд — принятый из адаптера пакет

будет приниматься не по прерыванию (сразу по приходу), а

BIOS обеспечивает поддержку LPT-порта, необходимую для

В процессе начального тестирования POST BIOS проверяет

ся не часто. Однако по-настоящему многозадачные ОС (например, NetWare) стараются работать с портом по прерываниям. Протестировать линию прерывания можно, только

#### 1.3.4. Функции BIOS для LPT-порта

ющие тайм-аут для этих портов.

организации вывода по интерфейсу Centronics.

по внешнему тайм-ауту.

наличие параллельных портов по адресам 3BCh, 378h и 278h и помещает базовые адреса обнаруженных портов в ячейки *BIOS Data Area 0:0408h, 040Ah, 040Ch, 040Eh.* Эти ячейки хранят адреса портов *LPT1-LPT4*, нулевое значение адреса является признаком отсутствия порта с данным номером. В

ячейки 0:0478, 0479, 047А, 047В заносятся константы, зада-

Поиск портов обычно ведется достаточно примитивно — по базовому адресу (в регистр данных предполагаемого порта) выводится тестовый байт (AAh или 55h), затем производится ввод по тому же адресу. Если считанный байт совпал с записанным, предполагается, что найден LPT-порт; его адрес помещается в ячейку BIOS Data Area. Базовые адреса портов могут быть впоследствии изменены программно. Адрес

рес помещается в ячейку *BIOS Data Area*. Базовые адреса портов могут быть впоследствии изменены программно. Адрес порта *LPT4* BIOS самостоятельно установить не может, поскольку в списке стандартных адресов поиска имеются только три указанных.

Обнаруженные порты *инициализируются* — записью в ретисть укразаномия, формуруются и суммостея смучет в 1814.

Обнаруженные порты *инициализируются* — записью в регистр управления формируется и снимается сигнал Init#, после чего записывается значение 0Ch, соответствующее исходному состоянию сигналов интерфейса. В некоторых случаях сигнал Init# активен с момента аппаратного сброса до инициализации порта во время загрузки ОС. Это можно за-

тор *On-Line*. Следствие этого явления — невозможность распечатки экранов (например, параметров BIOS Setup) по клавише Print Screen до загрузки ОС. Программное прерывание BIOS INT 17h обеспечивает следу-

метить по поведению включенного принтера во время перезагрузки компьютера — у принтера надолго гаснет индика-

ющие функции поддержки LPT-порта: 00h — вывод символа из регистра AL по протоколу Centronics (без аппаратных прерываний). Данные помещаются в выходной регистр, и, дождавшись готовности принтера (снятия сигнала Busy), формируется строб.

- 01h *инициализация* интерфейса и принтера (установка исходных уровней управляющих сигналов, формирова-
- ние импульса Init#, запрет аппаратных прерываний и переключение на вывод двунаправленного интерфейса). 02h — *опрос состояния* принтера (чтение регистра состояния порта).
- При вызове INT 17h номер функции задается в регистре AH, номер порта — в регистре DX (0 — LPT1, 1 — LPT2...). При возврате регистр АН содержит код состояния — биты регистра состояния SR[7:3] (биты 6 и 3 инвертированы) и флаг таймаута в бите 0. Флаг тайм-аута устанавливается при неудачной попытке вывода символа, если сигнал Busy не снимается в течение времени, определенного для данного порта в ячейках тайм-аута. В этом случае, согласно протоколу Centronics, строб данных не вырабатывается.

Перехват прерывания *INT 17h* является удобным способом внедрения собственных драйверов принтера. Потребность в них может возникать при подключении к порту принтера с интерфейсом ИРПР или необходимости перекодировки символов.

## 2. Последовательные интерфейсы Последовательный интерфейс для передачи данных исполь-

зует одну сигнальную линию, по которой информационные биты передаются друг за другом последовательно. Отсюда название интерфейса и порта. Английские термины — Serial Interface и Serial Port (иногда их неправильно переводят как «серийные»). Последовательная передача позволяет сократить количество сигнальных линий и увеличить дальность связи. Характерной особенностью является применение не-

ТТЛ сигналов. В ряде последовательных интерфейсов при-

меняется гальваническая развязка внешних (обычно входных) сигналов от схемной земли устройства, что позволяет соединять устройства, находящиеся под разными потенциалами. Ниже будут рассмотрены интерфейсы RS-232C, RS-422A, RS-423A, RS-485, токовая петля, MIDI, а также СОМ-порт.

#### 2.1. Способы последовательной передачи

асинхронном или синхронном режимах. При асинхронной передаче каждому байту предшествует старт-бит, сигнализирующий приемнику о начале посылки, за которым следуют биты данных и, возможно, бит паритета (четности). Завер-

Последовательная передача данных может осуществляться в

шает посылку *стоп-бит*, гарантирующий паузу между посылками (рис. 2.1). Старт-бит следующего байта посылается в любой момент после стоп-бита, то есть между передачами возможны паузы произвольной длительности. Старт-бит, имеющий всегда строго определенное значение (логический 0), обес-

печивает простой механизм синхронизации приемника по

сигналу от передатчика. Подразумевается, что приемник и передатчик работают на одной скорости обмена. Внутренний генератор синхронизации приемника использует счетчик-делитель опорной частоты, обнуляемый в момент приема начала старт-бита. Этот счетчик генерирует внутренние стробы,

по которым приемник фиксирует последующие принимаемые

биты. В идеале стробы располагаются в середине битовых интервалов, что позволяет принимать данные и при незначительном рассогласовании скоростей приемника и передатчика. Очевидно, что при передаче 8 бит данных, одного контрольного и одного стоп-бита предельно допустимое рассогласование скоростей, при котором данные будут распознаны верно, не может превышать 5%. С учетом фазовых искажений и дискретности работы внутреннего счетчика синхронизации реально допустимо меньшее отклонение частот. Чем меньше коэффициент деления опорной частоты внутреннего генератора (чем выше частота передачи), тем больше погрешность привязки стробов к середине битового интервала, и требования к согласованности частот становятся более строгими. Чем выше частота передачи, тем больше влияние искажений фронтов на фазу принимаемого сигнала. Взаимодействие этих факторов приводит к повышению требований к согласованности частот приемника и передатчика с ростом частоты обмена.



Рис. 2.1. Формат асинхронной передачи

Формат асинхронной посылки позволяет выявлять возможные *ошибки передачи*:

- Если принят перепад, сигнализирующий о начале посылки, а по стробу старт-бита зафиксирован уровень логической единицы, старт-бит считается ложным и приемник снова переходит в состояние ожидания. Об этой ошибке приемник может и не сообщать.
- Если во время, отведенное под стоп-бит, обнаружен уровень логического нуля, фиксируется ошибка стоп-бита.
- ж Если применяется контроль четности, то после посылки бит данных передается контрольный бит. Этот бит до-

полняет количество единичных бит данных до четного или нечетного в зависимости от принятого соглашения. Прием байта с неверным значением контрольного бита приводит к фиксации ошибки.

Контроль формата позволяет обнаруживать обрыв линии: при этом принимаются логический нуль, который сначала

трактуется как старт-бит, и нулевые биты данных, потом срабатывает контроль стоп-бита.

Для асинхронного режима принят ряд *стандартных скоростей обмена*: 50, 75, 110, 150, 300, 600, 1200, 2400, 4800, 9600, 19 200, 38 400, 57 600 и 115 200 бит/с. Иногда вместо единицы измерения «бит/с» используют «бод» (baud), но при рассмотрении двоичных передаваемых сигналов это некорректно. В бодах принято измерять частоту изменения состояния линии, а при недвоичном способе кодирования (ши-

жении А). Количество бит данных может составлять 5, 6, 7 или 8 (5- и 6-битные форматы распространены незначительно). Количество стоп-бит может быть 1, 1,5 или 2 («полтора бита»

роко применяемом в современных модемах) в канале связи скорости передачи бит (бит/с) и изменения сигнала (бод) могут отличаться в несколько раз (подробнее см. в прило-

означает только длительность стопового интервала). Асинхронный обмен в РС реализуется с помощью *COM-пор*та с использованием протокола *RS-232C*.

Синхронный режим передачи предполагает постоянную активность канала связи. Посылка начинается с синхробайта, за которым сразу же следует поток информационных бит. Если у передатчика нет данных для передачи, он заполняет паузу непрерывной посылкой байтов синхронизации. Очевидно, что при передаче больших массивов данных накладные расхолы на синхронизацию в данном режиме булут ниже

паузу непрерывной посылкой байтов синхронизации. Очевидно, что при передаче больших массивов данных накладные расходы на синхронизацию в данном режиме будут ниже, чем в асинхронном. Однако в синхронном режиме необходима внешняя синхронизация приемника с передатчиком, поскольку даже малое отклонение частот приведет к искажению принимаемых данных. Внешняя синхронизация возможна либо с помощью отдельной линии для передачи сигнала синхронизации, либо с использованием самосин-

SDLC (дорогие), поддерживающие синхронный режим обмена. Они используются в основном для связи с большими машинами (mainframes) IBM и мало распространены. Из синхронных адаптеров в настоящее время применяются адаптеры интерфейса V.35. RS-232C RS-422A L = 12 M  $V = 10 \, MG \mu T/c$ V = 20 Кбит/с L = 120 m V = 1 MGut/cL = 1200 M V = 100 Кбит/с

хронизирующего кодирования данных, при котором на стороне приемника из принятого сигнала могут быть выделены импульсы синхронизации. В любом случае синхронный режим требует дорогих линий связи или оконечного оборудования. Для РС существуют специальные платы — адаптеры



На физическом ировне последовательный интерфейс имеет

различные реализации, различающиеся способом передачи электрических сигналов. Существует ряд родственных международных стандартов: RS-232C, RS-423A, RS-422A и RS-485. На рис. 2.2 приведены схемы соединения приемни-

ков и передатчиков, а также показаны ограничения на дли-

ну линии (L) и максимальную скорость передачи данных (V). Несимметричные линии интерфейсов RS-232C и RS-423A имеют самую низкую защищенность от синфазной помехи,

хотя дифференциальный вход приемника RS-423A несколь-

аналог *RS-485*, работающие на симметричных линиях связи. В них для передачи каждого сигнала используются дифференциальные сигналы с отдельной (витой) парой проводов.

В перечисленных стандартах сигнал представляется *потенциалом*. Существуют последовательные интерфейсы, где информативен ток, протекающий по общей цепи передатчик-приемник — «токовая петля» и МІОІ. Для связи на короткие расстояния приняты стандарты беспроводной инфракрасной связи. Наибольшее распространение в РС получил простейший из перечисленных — стандарт *RS-232C*, реализуемый СОМ-портами. В промышленной автоматике широко применяется *RS-485*, а также *RS-422A*, встречающийся и в некоторых принтерах. Существуют преобразователи сигналов для согласования этих родственных ин-

ко смягчает ситуацию. Лучшие параметры имеет двухточечный интерфейс RS-422A и его магистральный (шинный)

#### 2.2. Интерфейс RS-232C

терфейсов.

передающей или принимающей данные (*OOД* — оконечное оборудование данных или *АПД* — аппаратура передачи данных; *DTE* — *Data Terminal Equipment*), к оконечной аппаратуре каналов данных (*AKД*; *DCE* — *Data Communication Equipment*). В роли АПД может выступать компьютер, принтер, плоттер и другое периферийное оборудование. В роли АКД обычно выступает модем. Конечной целью подключения является соединение двух устройств АПД. Полная схема соединения приведена на рис. 2.3. Интерфейс позволяет исключить канал удаленной связи вместе с парой устройств

Интерфейс предназначен для подключения аппаратуры,

АПД, соединив устройства непосредственно с помощью нульмодемного кабеля (рис. 2.4).

Стандарт описывает управляющие сигналы интерфейса, пересылку данных, электрический интерфейс и типы разъемов. В стандарте предусмотрены асинхронный и синхрон-

ный режимы обмена, но СОМ-порты поддерживают только

асинхронный режим. Функционально RS-232C эквивалентен стандарту МККТТ V.24/ V.28 и стыку C2, но они имеют различные названия сигналов.



Рис. 2.3. Полная схема соединения по RS-232C



Рис. 2.4. Соединение по RS-232C нуль-модемным кабелем

### 2.2.1. Электрический интерфейс

ятие сигналов.

Стандарт RS-232C использует несимметричные передатчики и приемники — сигнал передается относительно общего провода — схемной земли (симметричные дифференциальные сигналы используются в других интерфейсах — например, RS-422). Интерфейс НЕ ОБЕСПЕЧИВАЕТ ГАЛЬВАНИЧЕСКОЙ РАЗВЯЗКИ устройств. Логической единице

ЧЕСКОЙ РАЗВЯЗКИ устройств. Логической единице соответствует напряжение на входе приемника в диапазоне −12...−3 В. Для линий управляющих сигналов это состояние называется ON («включено»), для линий последовательных данных — MARK. Логическому нулю соответствует диапазон +3...+12 В. Для линий управляющих сигналов состояние называется OFF («выключено»), а для линий последователь-

называется *OFF* («выключено»), а для линии последовательных данных — *SPACE*. Диапазон –3...+3 В — зона нечувствительности, обусловливающая гистерезис приемника: состояние линии будет считаться измененным только после пересечения порога (рис. 2.5). Уровни сигналов на выходах

передатчиков должны быть в диапазонах –12...–5 В и +5...+12 В для представления единицы и нуля соответственно. Разность потенциалов между схемными землями (SG) соединяемых устройств должна быть менее 2 В, при более высокой разности потенциалов возможно неверное воспри-

Интерфейс предполагает наличие ЗАЩИТНОГО ЗАЗЕМЛЕ-НИЯ для соединяемых устройств, если они оба питаются от сети переменного тока и имеют сетевые фильтры.

Подключение и отключение интерфейсных кабелей устройств с автономным питанием должно производиться при отключенном питании. Иначе разность невыровненных потенциалов устройств в момент коммутации может оказаться приложенной к выходным или входным (что опаснее) цепям интерфейса и вывести из строя микросхемы.

+12 B



Для интерфейса RS-232C специально выпускаются буфер-

ные микросхемы приемников (с гистерезисом и передатчиком двуполярного сигнала). При несоблюдении правил заземления и коммутации они обычно являются первыми жертвами «пиротехнических» эффектов. Иногда их устанавливают в «кроватках», что облегчает замену. Цоколевка микросхем формирователей сигналов RS-232C приведена на рис. 2.6. Часто буферные схемы входят прямо в состав интерфейсных БИС. Это удешевляет изделие, экономит место на плате, но в случае аварии оборачивается крупными финансовыми потерями. Вывести из строя интерфейсные микросхемы замыканием сигнальных цепей маловероятно: ток короткого замыкания передатчиков обычно не превосходит 20 мА



VEE [] 1

1A 🗆 2 1Y[]3

28₵5

2Y 🗆 6

GND ☐ 7

**Рис. 2.6.** Формирование сигналов RS-232C; *а* — приемник 1489 (А — вход RS-232, С — управление гистерезисом (ТТЛ), Y — выход ТТЛ);  $\delta$  — передатчик 1488 (A, B — входы ТТЛ, Y — выход RS-232,

1488

14 DVDD 13 🗖 4A

12 🗖 4B

11 🗖 4Y

10 🗆 3A

9 🏻 3B

8 □3Y

0 VDD

1 VDD

0 VDD

1A 🗆 1

1C[2

1Y 🛛 3

2A□4 2C 🗆 5

2Y 🗆 6 GND 7

мов.

1489

14 DVCC

13 🗆 4A

12 14C

11 D4Y

10 D 3A

9 D3C

8 □ 3Y

Рис. 2.7. Кабели подключения модемов

SG

SG 5

Если аппаратура *АПД* соединяется без модемов, то разъемы устройств (вилки) соединяются между собой *нуль-модемным кабелем* (Zero-modem или Z-modem), имеющим на обоих концах розетки, контакты которых соединяются перекрестно по одной из схем, приведенных на рис. 2.8.



**Рис. 2.8.** Нуль-модемный кабель: a — минимальный,  $\delta$  — полный

Если на каком-либо устройстве *АПД* установлена розетка — это почти стопроцентный признак того, что к другому устройству оно должно подключаться прямым кабелем, аналогичным кабелю подключения модема. Розетка устанавливается обычно на тех устройствах, у которых удаленное подключение через модем не предусмотрено.

В табл. 2.1 приведено назначение контактов разъемов СОМпортов (и любой другой аппаратуры *АПД*). Контакты разъема DB-25S определены стандартом EIA/TIA-232-E, разъем DB-9S описан стандартом EIA/ TIA-574. У модемов название цепей и контактов такое же, но роли сигналов (входвыход) меняются на противоположные.

Подмножество сигналов RS-232C, относящихся к асинхронному режиму, рассмотрим с точки зрения СОМ-порта РС. Следует помнить, что активному состоянию сигнала («включено») и логической единице передаваемых данных соответствует отрицательный потенциал (ниже –3 В) сигнала интерфейса, а состоянию «выключено» и логическому нулю — положительный (выше +3 В). Назначение сигналов интерфейса приведено в табл. 2.2.

## Таблица 2.1. Разъемы и сигналы интерфейса RS-232C

| Обознач<br>цепи | бозначение<br>епи  |                                       | Контакт<br>разъема  |                 | ер про<br>ля вы<br>ема РО<br>ренне | Направление<br>I/O |       |              |
|-----------------|--------------------|---------------------------------------|---------------------|-----------------|------------------------------------|--------------------|-------|--------------|
| RS-232          | Стык 2             | DB-25S                                | DB-9S               | 1*              | 2*                                 | 3*                 | 4*    |              |
| PG              | 101                | 7                                     | 5                   | (10)            | (10)                               | (10)               | 1     |              |
| SG              | 102                | 7                                     | 5                   | 5               | 9                                  | 1                  | 13    | _            |
| TD              | 103                | 2                                     | 3                   | 3               | 5                                  | 3                  | 3     | 0            |
| RD              | 104                | 3                                     | 2                   | 2               | 3                                  | 4                  | 5     | I            |
| RTS             | 105                | 4                                     | 7                   | 7               | 4                                  | 8                  | 7     | 0            |
| CTS             | 106                | 5                                     | 8                   | 8               | 6                                  | 7                  | 9     | I            |
| DSR             | 107                | 6                                     | 6                   | 6               | 2                                  | 9                  | 11    | I            |
| DTR             | 108/2              | 20                                    | 4                   | 4               | 7                                  | 2                  | 14    | 0            |
| DCD             | 109                | 8                                     | 1                   | 1               | 1                                  | 5                  | 15    | I            |
| Ri              | 125                | 22                                    | 9                   | 9               | 8                                  | 6                  | 18    | I            |
| 2* 1<br>3* 1    | шлейф 1<br>вариант | -битных<br>6-битны<br>шлейфа<br>шлейф | х мульт<br>портов і | икарт<br>на сис | гемнь                              | іх пл              | атах. | емных платах |

# Таблица 2.2. Назначение сигналов интерфейса RS-232C

PG

# Сигнал Назначение

Protected Ground — защитная земля, соединяется с корпусом устройства и экраном кабеля SG Signal Ground - сигнальная (схемная) земля, относительно которой действуют уровни сигналов

TD Transmit Data - последовательные данные - выход передатчика

RD Receive Data - последовательные данные - вход при-

емника

RTS Request To Send - выход запроса передачи данных: состояние «включено» уведомляет модем о наличии у

терминала данных для передачн. В полудуплексном режиме используется для управления направлением состоянне «включено» служит сигналом модему на переключение в режим передачи

### Таблица 2.2 (продолжение)

| Сигнал | Назначение                                                                                                                                                                                           |
|--------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| СТЅ    | Clear To Send — вход разрешения терминалу передавать данные. Состояние «выключено» аппаратно запрещает передачу данных. Сигнал используется для аппаратного управления потоками данных               |
| DSR    | Data Set Ready — вход сигнала готовности от аппаратуры передачи данных (модем в рабочем режиме подключен к каналу и закончил действия по согласованию с аппаратурой на противоположном конце канала) |
| DTR    | Data Terminal Ready — выход сигнала готовности тер-<br>минала к обмену данными. Состояние «включено» под-<br>держивает коммутируемый канал в состоянии соеди-<br>нения                               |
| DCD    | Data Carrier Detected — вход сигнала обпаружения несущей удаленного модема                                                                                                                           |
| RI     | Ring Indicator — вход индикатора вызова (звонка). В коммутируемом канале этим сигналом модем сигнализирует о принятии вызова                                                                         |

# 2.2.2. Управление потоком данных

Для управления потоком данных (Flow Control) могут использоваться два варианта протокола — аппаратный и программный. Иногда управление потоком путают с квитированием, но это разные методы достижения одной цели согласования темпа передачи и приема. Квитирование (Handshaking) подразумевает посылку уведомления о получении элемента, в то время как управление потоком предпо-

лагает посылку уведомления о невозможности последующего приема данных. Аппаратный протокол управления потоком RTS/CTS

(Hardware Flow Control) использует сигнал СТS, который позволяет остановить передачу данных, если приемник не готов к их приему (рис. 2.9). Передатчик «выпускает» очередной байт только при включенной линии CTS. Байт, который уже начал передаваться, задержать сигналом CTS невозможно (это гарантирует целостность посылки). Аппаратный протокол обеспечивает самую быструю реакцию передатчика на состояние приемника. Микросхемы асинхронных приемопередат-

чиков имеют не менее двух регистров в приемной части —

сдвигающий, для приема очередной посылки, и хранящий, из которого считывается принятый байт. Это позволяет реализовать обмен по аппаратному протоколу без потери данных.



Аппаратный протокол удобно использовать при подключении принтеров и плоттеров, если они его поддерживают

нии двух компьютеров аппаратный протокол требует перекрестного соединения линий RTS — CTS. Если аппаратный протокол не используется, у передающего

(рис. 2.10). При непосредственном (без модемов) соедине-

терминала должно быть обеспечено состояние «включено» на линии СТS перемычкой RTS — СТS. В противном случае передатчик будет «молчать».



**Рис. 2.10.** Кабель подключения принтера с протоколом RTS-CTS Программный протокол управления потоком XON/XOFF пред-

полагает наличие двунаправленного канала передачи данных.

Работает протокол следующим образом: если устройство, принимающее данные, обнаруживает причины, по которым не может их дальше принимать, оно по обратному последовательному каналу посылает байт-символ *XOFF* (13h). Противоположное устройство, приняв этот символ, приостанавливает передачу. Когда принимающее устройство снова

становится готовым к приему данных, оно посылает символ

возобновляет передачу. Время реакции передатчика на изменение состояния приемника по сравнению с аппаратным протоколом увеличивается по крайней мере на время передачи символа (XON или XOFF) плюс время реакции программы передатчика на прием символа (рис. 2.11). Из этого следует, что данные без потерь могут приниматься только приемником, имеющим дополнительный буфер принимаемых данных и сигнализирующим о неготовности заблаго-

**XON** (11h), приняв который противоположное устройство



**Рис. 2.11.** Программное управление потоком XON/XOFF
Преимущество программного протокола заключается в от-

сутствии необходимости передачи управляющих сигналов интерфейса — минимальный кабель для двустороннего обмена может иметь только 3 провода (см. рис. 2.8а). Недостатком, кроме требования наличия буфера и большего времени реакции (снижающего общую производительность канала из-за ожидания сигнала XON), является сложность реализации полнодуплексного режима обмена. В этом случае из потока принимаемых данных должны выделяться (и обрабатываться) символы управления потоком, что ограничивает набор передаваемых символов. Минимальный вариант кабеля для подключения принтера (плоттера) с протоколом XON/XOFF привелен на рис. 2.12.

колом XON/XOFF приведен на рис. 2.12. Кроме этих двух распространенных стандартных протоколов, поддерживаемых и ПУ, и ОС, существуют и другие. Некоторые плоттеры с последовательным интерфейсом используют программное управление, но посылают не стандартные символы XON/XOFF, а слова (ASCII-строки). Такой обмен на уровне системной поддержки протокола практически не поддерживается (эти плоттеры непосредственно

ройства вывода обычно не вызывает восторга у системного программиста. Кабель для подключения совпадает с приведенным на рис. 2.12.

— DB9S
— DB9P
— DB25P

«разговаривают» с прикладной программой). Конечно, можно написать драйвер СОМ-порта (перехватчик *INT 14h*), но необходимость обработки в нем текстовых сообщений от уст-



Рис. 2.12. Кабель подключения принтера по протоколу XON/XOFF

# 2.3. Интерфейс «токовая петля»

са является токовая петля. В ней электрическим сигналом является не уровень напряжения относительно общего провода, а *ток* в двухпроводной линии, соединяющей приемник и передатчик. Логической единице (состоянию «включено») соответствует протекание тока 20 мA, а логическому нулю —

Распространенным вариантом последовательного интерфей-

ного формата асинхронной посылки позволяет обнаружить обрыв линии — приемник заметит отсутствие стоп-бита (обрыв линии действует как постоянный логический нуль).
Токовая петля обычно предполагает гальваническую развяз-

отсутствие тока. Такое представление сигналов для описан-

Токовая петля обычно предполагает гальваническую развязку входных цепей приемника от схемы устройства. При этом источником тока в петле является передатчик (этот вариант называют активным передатчиком). Возможно и питание от приемника (активный приемник), при этом выходной ключ передатчика может быть также гальванически развязан с остальной схемой передатчика. Существуют упрощенные варианты без гальванической развязки, но это уже вырожденный случай интерфейса.

этом каждый приемник «слышит» как сигналы передатчика на противоположной стороне канала, так и сигналы своего передатчика. Они расцениваются коммуникационными пакетами просто как эхо-сигнал. Для безошибочного приема пе-

Преобразовать сигналы RS-232C в токовую петлю можно с помощью несложной схемы (рис. 2.13). Здесь принтер подключается по токовой петле к СОМ-порту с аппаратным управлением потоком. Для получения двуполярного сигна-

Токовая петля с гальванической развязкой позволяет передавать сигналы на расстояния до нескольких километров. Расстояние определяется сопротивлением пары проводов и уровнем помех. Поскольку интерфейс требует пары проводов для каждого сигнала, обычно используют только два сигнала интерфейса. В случае двунаправленного обмена применяются только сигналы передаваемых и принимаемых данных, а для управления потоком используется программный метод XON/XOFF. Если двунаправленный обмен не требуется, используют одну линию данных, а для управления потоком обратная линия задействуется для сигнала CTS (аппаратный протокол) или встречной линии данных (про-

ла, требуемого для входных сигналов СОМ-порта, применяется питание от интерфейса. При надлежащем ПО одной токовой петлей можно обеспечить двунаправленную полудуплексную связь двух устройств. При редатчики должны работать поочередно.

граммный протокол).

DB9S **DB25S** ŔĎ (+) DTR 4 20 DSR (-) 10K RTS RTS(+) CTS 5 8

Рис. 2.13. Подключение принтера с интерфейсом «токовая петля» к СОМ-порту

# 2.4. Интерфейс MIDI

Цифровой интерфейс музыкальных инструментов *MIDI* (Musical Instrument Digital Interface) является двунаправленным последовательным асинхронным интерфейсом с частотой передачи 31,25 Кбит/с. Этот интерфейс, разработанный в 1983 году, стал фактическим стандартом для

ный в 1983 году, стал фактическим стандартом для сопряжения компьютеров, синтезаторов, записывающих и воспроизводящих устройств, микшеров, устройств специаль-

5 мА) с гальванической развязкой входной цепи. Это исключает связь «схемных земель» соединяемых устройств через интерфейсный кабель, устраняя помехи, крайне нежелательные для звуковой техники. Снижению интерференционных

воспроизводящих устройств, микшеров, устройств специальных эффектов и другой электромузыкальной техники. В интерфейсе применяется токовая петля 10 мА (возможно

помех служит и выбор частоты передачи, которая совпадает с одним из значений частот квантования, принятых в цифровой звукозаписи.

Асинхронная посылка содержит старт-бит, 8 бит информации и 1 стоп-бит, контроль четности отсутствует. Старший бит посылки является признаком «команда/данные». Его нулевое значение указывает на наличие семи бит данных в младчих разридах. При единициом значении биты [6:4] содержим установания биты [6:4] содержим станования посылки.

вое значение указывает на наличие семи бит данных в младших разрядах. При единичном значении биты [6:4] содержат код команды, а биты [3:0] — номер канала. Команды могут быть как адресованными конкретному каналу, так и широковещательными безадресными. К последней группе относятся команды старта, стопа и отметки времени, обеспечивающие синхронизацию устройств (система синхронизации MIDI Sync и MTC — MIDI Time Code).

Интерфейс определяет три типа портов: MIDI-In, MIDI-Out и MIDI-Thru.

Входной порт MIDI-In представляет собой вход интерфейса «токовая петля 10 мА», гальванически развязанного от приемника оптроном с быстродействием не хуже 2 мкс. Устройство отслеживает информационный поток на этом входе и

ство отслеживает информационный поток на этом входе и реагирует на адресованные ему команды и данные. Выходной порт MIDI-Out представляет собой выход источника тока 10 мА, гальванически связанного со схемой уст-

точник 5 В. На выход подается информационный поток от данного устройства. В потоке может содержаться и транслированный входной поток.

Транзитный порт MIDI-Thru (не обязателен) служит для ре-

ройства. Ограничительные резисторы предохраняют выходные цепи от повреждения при замыкании на землю или ис-

трансляции входного сигнала.

В качестве разъемов применяются 5-контактные разъемы DIN, распространенные в бытовой звуковой аппаратуре. На всех устройствах устанавливаются розетки, на кабелях — вилки. Все

соединительные кабели MIDI унифицированы (рис. 2.14). Контакт 2 — экран кабеля — соединяется с общим проводом

только на стороне передатчика (на разъемах MIDI-Out и MIDI-Thru).

Рис. 2.14. Соединительные кабели MIDI
В маркировке входов и выходов, указанной около разъемов,

бывают разночтения. Одни производители пишут «In» или «Out» в соответствии с функцией разъема данного устройства (и это правильно), тогда любой кабель соединяет «In» и «Out». Другие считают, что подпись должна обозначать функцию подключаемого устройства. Тогда кабель будет соединять разъемы с обозначениями «In» — «In» и «Out» — «Out».

Интерфейс позволяет объединить группу до 16 устройств в локальную сеть. Топология должна подчиняться правилу: вход *MIDI-In* одного устройства должен подключаться к выходу *MIDI-Out* или *MIDI-Thru* другого. При планировании MIDI-сети необходимо руководствоваться информационными потоками и связью устройств. Управляющие устройства — клавиатуры, секвенсоры (в режиме воспроиз-

вается в специальный кабель, схема которого приведена на рис. 2.16. Некоторые модели РС имеют встроенные адаптеры и стандартные 5-штырьковые разъемы MIDI.

IN OUT IN OUT IN OUT THRU

Устройство 1 Устройство 2 Устройство 3 Устройство 4

ведения), источники синхронизации — должны находиться перед управляемыми. Если устройства нуждаются в двунаправленном обмене, они соединяются в кольцо. Возможно применение специальных мультиплексоров, позволяющих логически коммутировать несколько входных потоков в один выходной. Вырожденным случаем кольца является двунаправленное соединение двух устройств. Несколько вариан-

В РС MIDI-порт имеется на большинстве звуковых адаптеров, его сигналы выведены на неиспользуемые контакты (12 и 15) разъема игрового адаптера. Для подключения устройств MIDI требуется *переходной адаптер*, реализующий интерфейс «токовая петля». Переходной адаптер обычно встраи-

тов соединения приведено на рис. 2.15.

**Рис. 2.15.** Варианты топологии сети MIDI: a — цепь, 6 — кольцо с мультиплексором

В РС для интерфейса MIDI применяются порты, совместимые с контроллером *MPU-401* (Roland) в режиме UART. В пространстве ввода/вывода *MPU-401* занимает два смеж-

ных адреса *MPU* (обычно 330h) и *MPU+1*:

« Порт *DATA* (адрес *MPU+0*) — запись и считывание байт, передаваемых и принимаемых по интерфейсу MIDI.

Порт STATUS/COMMAND (адрес MPU+1) — чтение состояния / запись команд (запись — только для интеллектуального режима). В байте состояния определены следующие биты:

дующие биты: Бит 7 - DSR (Data Set Ready) — готовность (DSR=0) принятых данных для чтения. Бит устанавливается в «1», когда все принятые байты считаны из регистра данных.

Бит 6 - DRR (Data Read Ready) — готовность (DRR=0) UART к записи в регистр данных или команд. Условие готовности к записи не возникнет, если приемник имеет непрочитанный байт данных.



Рис. 2.16. Вариант схемы кабеля-адаптера MIDI

На некоторых системных платах применяются БИС контроллеров интерфейсов, в которых UART, используемая для СОМ-порта, конфигурированием через BIOS SETUP может быть переведена в режим MIDI-порта.

# 2.5. СОМ-порт

Последовательный интерфейс *COM-nopm* (Communication Port — коммуникационный порт) появился в первых моделях IBM PC. Он был реализован на микросхеме асинхронного приемопередатчика Intel 8250. Порт имел поддержку BIOS (*INT 14h*), однако широко применялось (и применяется) взаи-

модействие с портом на уровне регистров. Поэтому во всех РСсовместимых компьютерах для последовательного интерфейса применяют микросхемы приемопередатчиков, совместимые с редатчиком (УСАПП или USART — Universal Asynchronous Receiver-Transmitter). Совместимости с РС на уровне регистров СОМ-порта такие компьютеры не имеют. Хорошо, если у соответствующих компьютеров имеется «честный» драйвер BIOS INT 14h, а не заглушка, возвращающая состояние модема

i8250. В ряде отечественных РС-совместимых (почти) компьютеров для последовательного интерфейса применялась микросхема KP580BB51 — аналог i8251. Однако эта микросхема является универсальным синхронно-асинхронным приемопе-

«всегда готов» и ничего не делающая. Совместимость на уровне регистров СОМ-порта считается необходимой. Многие разработчики коммуникационных пакетов предлагают работу и через *BIOS INT 14h*, однако на высоких скоростях это неэффективно. Говоря о СОМ-порте РС, по умолчанию будем подразумевать совместимость регистровой модели с i8250 и реализацию асинхронного интерфейса *RS-232C*.

# 2.5.1. Использование СОМ-портов

манипуляторов (мышь, трекбол). В этом случае порт используется в режиме последовательного ввода; питание производится от интерфейса. Мышь с последовательным интерфейсом — Serial Mouse — может подключаться к любому исправному

порту. Для согласования разъемов порта и мыши возможно применение переходника DB-9S-DB-25P или DB-25S-DB-9P. Для мыши требуется прерывание, для порта *COM1* — IRQ4, для *COM2* — IRQ3. Жесткая привязка номера IRQ к номеру порта

СОМ-порты чаще всего применяют для подключения

обусловлена свойствами драйверов. Каждое событие — перемещение мыши или нажатие-отпускание кнопки — кодируется двоичной посылкой по интерфейсу *RS-232C*. Применяется асинхронная передача; двуполярное питание обеспечивается от уп-

# Таблица 2.3. Разъемы Serial Mouse

| Сигнал       | Контакты |       |  |  |  |  |
|--------------|----------|-------|--|--|--|--|
|              | DB-9     | DB-25 |  |  |  |  |
| Data         | 2        | 3     |  |  |  |  |
| GND          | 5        | 7     |  |  |  |  |
| +V (питание) | 4, 7     | 4, 20 |  |  |  |  |
| -V (питание) | 3        | 9     |  |  |  |  |

равляющих линий интерфейса (табл. 2.3).

левой, средней и правой кнопок, X[7:0] и Y[7:0] — биты относительного перемещения мыши с момента предыдущей посылки по координатам X и Y. Положительным значениям соответствует перемещение по координате X вправо, а по координате Y вниз для MS-Mouse и вверх для PC-Mouse. Отсюда становятся понятными беспорядочные перемещения курсора на экране при несоответствии драйвера типу мыши.

Таблица, 2.4. Формат пакета MS-Mouse

**D6** 

1

0

Биты

1-й байт

2-й байт

3-й байт

**D5** 

LB

**X**5

Y5

Tatinaga 2.5. Copust naceta PC-Mouse (Mouse Systems Mouse)

Две разновидности Serial Mouse — *MS-Mouse* и *PC-Mouse* (Mouse Systems Mouse) — требуют соответствующих драйверов, многие мыши имеют переключатель MS/PC. Мышь с «чужим» драйвером либо не отзывается, либо «скачет» загадочным образом. Эти разновидности используют различные форматы посылок: при одинаковой скорости 1200 бит/с, одном стоп-бите и отсутствии контроля четности Microsoft Mouse использует 7 бит данных, а PC-Mouse — 8 бит. Мышь посылает пакет при каждом изменении состояния — перемещении, нажатии или отпускании кнопки. Пакет, передаваемый MS-Mouse, состоит из трех байт (табл. 2.4). PC-Mouse передает 5 байт (табл. 2.5). Здесь *LB* (Left Buttom), *MB* (Middle Buttom) и *RB* (Right Buttom) означают состояние

| Биты      | D7 | D6 | D5 | D4 | D3 | D2 | D1 | DO |
|-----------|----|----|----|----|----|----|----|----|
| 1-й байт  | 1  | 0  | 0  | 0  | 0  | LB | MB | RB |
| 2 5 6 5 - | V7 | VC | VE | VI | V2 | Va | V4 | VA |

**D4** 

RB

X4

**Y4** 

D2

*Y6* 

X2

**Y2** 

D3

*Y*7

X3

**Y**3

D1

X7

X1

**Y1** 

DO

*X6* 

X0

**Y0** 

| 1-й байт | 1    | 0         | 0        | 0    | 10 | LB | MB | RB |
|----------|------|-----------|----------|------|----|----|----|----|
| 2-й байт | X7   | X6        | X5       | X4   | X3 | X2 | X1 | X0 |
| 3-й байт | Y7   | <i>Y6</i> | Y5       | Y4   | Y3 | Y2 | Y1 | Y0 |
| 4-й байт | Совп | адает с   | о 2-м ба | йтом |    |    |    |    |
| 5-й байт | Совп | адает с   | 3-м бай  | том  |    |    |    |    |

Для подключения внешних модемов используется полный (9-проводный) кабель *АПД-АКД*, схема которого приведена на рис. 2.7. Этот же кабель используется для согласования

реса) порта и линии прерывания. Если предполагается работа на скоростях 9600 бит/с и выше, то СОМ-порт должен быть реализован на микросхеме UART 16550A или совместимой. Возможности работы с использованием FIFO-буферов и обмена по каналам DMA зависят от коммуникационного ПО. Для **связи двух компьютеров**, удаленных друг от друга на небольшое расстояние, используют и непосредственное со-

единение их СОМ-портов нуль-модемным кабелем (рис. 2.8). Использование программ типа Norton Commander или Interlnk MS-DOS позволяет обмениваться файлами со ско-

разъемов (по количеству контактов); возможно применение переходников 9-25, предназначенных для мышей. Для работы коммуникационного ПО обычно требуется использование прерываний, но здесь есть свобода выбора номера (ад-

ростью до 115,2 Кбит/с без применения аппаратных прерываний. Это же соединение может использоваться и сетевым пакетом Lantastic, предоставляющим более развитый сервис. Подключение принтеров и плоттеров к СОМ-порту требует применения кабеля, соответствующего выбранному протоколу управления потоком: программному XON/XOFF или аппаратному RTS/CTS. Схемы кабелей приведены на рис. 2.10

и 2.12. Аппаратный протокол предпочтительнее. Прерывания при выводе средствами DOS (командами СОРУ или

**PRINT)** не используются. СОМ-порт используется для подключения электронных ключей (Security Devices), предназначенных для защиты от нелицензированного использования ПО. Эти устройства могут быть как «прозрачными», позволяя воспользоваться тем же портом для подключения периферии, так и полностью

занимающими порт. СОМ-порт при наличии соответствующей программной поддержки позволяет превратить РС в терминал, эмулируя си-

стему команд распространенных специализированных терминалов (VT-52, VT-100 и т. д.). Простейший терминал

получается, если замкнуть друг на друга функции BIOS обслуживания СОМ-порта (INT 14h), телетайпного вывода (INT 10h) и клавиатурного ввода (INT 16h). Однако такой терминал будет работать лишь на малых скоростях обмена (если, конечно, его делать не на Pentium), поскольку функции BIOS хоть и универсальны, но не слишком быстры. Интерфейс *RS-232C* широко распространен в различных ПУ

и терминалах. СОМ-порт может использоваться и как двунаправленный интерфейс, у которого имеется 3 программноуправляемые выходные линии и 4 программно-читаемые входные линии с двуполярными сигналами. Их использова-

ние определяется разработчиком. Существует, например, схема однобитного широтно-импульсного преобразователя, позволяющего записывать звуковой сигнал на диск РС, используя входную линию СОМ-порта. Воспроизведение этой записи через обычный динамик РС позволяет передать речь. В настоящее время, когда звуковая карта стала почти обязательным устройством РС, это не впечатляет, но когдато такое решение было интересным. СОМ-порт используют для беспроводных коммуникаций с применением излучателей и приемников инфракрасного диапазона — IR (Infra Red) Connection. Этот интерфейс позволяет осуществлять связь между парой устройств, удаленных на расстояние, достигающее нескольких метров. Раз-

личают инфракрасные системы низкой (до 115,2 Кбит/с),

средней (1,152 Мбит/с) и высокой (4 Мбит/с) скорости. Низкоскоростные системы служат для обмена короткими сообщениями, высокоскоростные — для обмена файлами между компьютерами, подключения к компьютерной сети, вывода на принтер, проекционный аппарат и т. п. Ожидаются более высокие скорости обмена, которые позволят передавать «живое видео». В 1993 году создана ассоциация разработчиков систем инфракрасной передачи данных *IrDA* (Infrared Data Association), призванная обеспечить совместимость оборудования от различных производителей. В настоящее время действует стандарт *IrDA* 1.1. Имеются собственные системы фирм Hewlett Packard — *HP-SIR* (Hewlett Packard Slow Infra Red) — и Sharp — *ASK* (Amplitude Shifted Keyed IR). Основные характеристики интерфейсов следующие:

IrDA SIR (Slow Infra Red), HP-SIR — 9,6−115,2 Кбит/с;
 IrDA MIR (Middle Infra Red) — 1,2 Мбит/с;

IrDA FIR (Fast Infra Red) — 4 Мбит/с;
 Sharp ASK — 9,6−57,6 Кбит/с.

можностью прямого управления шиной,

имеют некоторые модели принтеров.

может конфигурироваться порт *COM2*. В этом случае на переднюю панель компьютера устанавливается внешний приемопередатчик — «инфракрасный глаз», который подключается к разъему *IR-Connector* системной платы.

пользуются UART, совместимые с 16450/16550. В современных системных платах на использование инфракрасной связи

На средних и высоких скоростях обмена применяются специализированные микросхемы, ориентированные на интенсивный программно-управляемый обмен или DMA с воз-

Инфракрасные излучатели не создают помех в радиочастот-

ном диапазоне и обеспечивают конфиденциальность передачи. ИК-лучи не проходят через стены, поэтому зона приема ограничивается небольшим легко контролируемым пространством. Инфракрасная технология привлекательна для связи портативных компьютеров со стационарными компьютерами или док-станциями. Инфракрасный интерфейс

# **2.5.2. Микросхемы асинхронных приемопередатчиков** Преобразование параллельного кода в последовательный для

передачи и обратное преобразование при приеме данных выполняют специализированные микросхемы UART (Universal Asynchronous Receiver-Transmitter — универсальный асинхронный приемопередатчик). Эти же микросхемы формируют и обрабатывают управляющие сигналы интерфейса. COM-пор-

ный приемопередатчик). Эти же микросхемы формируют и обрабатывают управляющие сигналы интерфейса. СОМ-порты IBM PC XT/AT базируются на микросхемах, совместимых на уровне регистров с UART i8250 — 8250/16450/16550A. Это семейство представляет собой усовершенствование начальной

- модели, направленное на повышение быстродействия, снижение потребляемой мощности и загрузки процессора при интенсивном обмене. Отметим следующее:
- 8250 имеет ошибки (появление ложных прерываний),
   учтенные в XT BIOS.

совместимость с BIOS. Работает в некоторых моделях АТ, но непригоден для скорости 9600 бит/с.

8250В — исправлены ошибки 8250 и 8250А, восстановлена ошибка в прерываниях — возвращена совместимость с XT BIOS. Работает в АТ под DOS (кроме скорости

8250А — ошибки исправлены, в результате чего потеряна

Микросхемы 8250х имеют невысокое быстродействие по обращениям со стороны системной шины. Они не допускают обращения к своим регистрам в смежных шинных циклах процессора — для корректной работы с ними требуется вве-

9600 бит/с).

- дение программных задержек между обращениями СРU. В компьютерах класса АТ применяют микросхемы UART следующих модификаций:

  16450 быстродействующая версия 8250 для АТ. Оши-
- Требуется для работы OS/2 с COM-портами.

   16550 развитие 16450. Может использовать канал DMA для обмена данными. Имеет FIFO-буфер, но

бок 8250 и полной совместимости с XT BIOS не имеет.

- некорректность его работы не позволяет им воспользоваться.

  16550A имеет работающие 16-байтные FIFO-буферы приема и передачи и возможность использования DMA.
- Именно этот тип UART должен применяться в AT при интенсивных обменах на скоростях 9600 бит/с и выше. Совместимость с этой микросхемой обеспечивает большинство микросхем контроллеров портов ввода/вывода, входящих в современные чипсеты.
- входящих в современные чипсеты.
  Микросхемы UART 16550A с программной точки зрения представляют собой набор регистров, доступ к которым определяется адресом (смешением адреса регистра относи-
- определяется адресом (смещением адреса регистра относительно базового адреса порта) и значением бита *DLAB* (бита 7 регистра *LCR*). В адресном пространстве микросхема занимает 8 смежных адресов. Список регистров UART 16550A и способы доступа к ним приведены в табл. 2.6. Микросхемы 8250 отличаются отсутствием регистра *FCR* и всех воз-

можностей FIFO и DMA.

## Таблица 2.6. Регистры UART 16550A

| Доступ     |                          | Регис | тр                                   | Чтение/запись<br>R/W |  |
|------------|--------------------------|-------|--------------------------------------|----------------------|--|
| Смещение   | ещение DLAB Имя Название |       |                                      |                      |  |
| 0h         | 0                        | THR   | Transmit Holding Register            | wo                   |  |
| 0h         | 0                        | RBR   | Receiver Buffer Register             | RO                   |  |
| 0h         | 1                        | DLL   | Divisor Latch LSB                    | R/W                  |  |
| 1h         | 1                        | DLM   | Divisor Latch MSB                    | R/W                  |  |
| <b>1</b> h | 0                        | IER   | Interrupt Enable Register            | R/W                  |  |
| 2h         | x                        | IIR   | Interrupt Identification<br>Register | RO                   |  |
| 2h         | х                        | FCR   | FIFO Control Register                | wo                   |  |
| 3h         | х                        | LCR   | Line Control Register                | R/W                  |  |
| 4h         | х                        | MCR   | Modem Control Register               | R/W                  |  |
| 5h         | х                        | LSR   | Line Status Register                 | R/W*                 |  |
| 6h         | х                        | MSR   | Modem Status Register                | R/W*                 |  |
| <b>7</b> h | х                        | SCR   | Scratch Pad Register                 | R/W                  |  |

\* Некоторые биты допускают только чтеиие. Запись в регистр может привести к сбою протокола.

ТНЯ — промежуточный регистр данных передатчика (только для записи). Данные, записанные в регистр, будут пересланы в выходной сдвигающий регистр (когда он будет свободен), из которого поступят на выход при наличии разрешающего сигнала СТЅ. Бит 0 передается (и принимается) первым. При длине посылки менее 8 бит старшие биты игнорируются.

**RBR** — буферный регистр принимаемых данных (только для чтения). Данные, принятые входным сдвигающим регистром, помещаются в регистр *RBR*, откуда они могут быть считаны процессором. Если к моменту окончания приема очередного символа предыдущий не был считан из регистра, фиксируется ошибка переполнения. При длине посылки менее 8 бит старшие биты в регистре имеют нудевое значение.

DLL — регистр младшего байта делителя частоты.

**DLM** — регистр старшего байта делителя частоты. Делитель определяется по формуле D=115200/V, где V  $\,-\,$  скорость пе-

редачи, бит/с. Входная частота синхронизации 1,8432 МГц делится на заданный коэффициент, после чего получается 16-кратная частота передачи данных.

IER — регистр разрешения прерываний. Единичное значение бита разрешает прерывание от соответствующего источника.

Назначение бит регистра IER: Биты 7-4=0 — не используются.

Бит 3 - Mod IE - по изменению состояния модема (любой из линий CTS, DSR, RI, DCD).

Бит 2 - RxL IE - по обрыву/ошибке линии.Бит 1 - TxD IE - по завершении передачи.

Бит 0 - RxD IE - по приему символа (в режиме FIFO прерывание по тайм-ауту).

*IIR* — регистр идентификации (только для чтения) прерываний и признака режима FIFO. Для упрощения программного анализа UART выстраивает внутренние запросы прерывания по четырехуровневой системе приоритетов. Порядок приоритетов (по убыванию): состояние линии, прием символа, освобождение регистра передатчика, состояние модема. При воз-

никновении условий прерывания UART указывает на источник с высшим приоритетом до тех пор, пока он не будет сброшен соответствующей операцией. Только после этого будет выставлен запрос с указанием следующего источника.

Назначение бит регистра //R: Биты [7:6] — признак режима FIFO: 11 — режим FIFO 16550A,

10 — режим FIFO 16550, 00 — обычный.

Биты [5:4] — не используются.

стояния линии.

Бит 3 — прерывание по тайм-ауту (не в режиме FIFO).

Биты [2:1] - причина прерывания с наивысшим приоритетом (в обычном, не FIFO-режиме): 11 — ошибка/обрыв линии; сброс — чтением регистра со-

00 — изменение состояния модема; сброс — чтением регистра состояния модема. Бит 0 — признак необслуженного запроса прерывания: нет запроса. 0 — есть запрос. Идентификация прерываний в режиме FIFO, IIR [3:1]: 011 — ошибка/обрыв линии; сброс — чтением регистра состояния линии. 010 — принят символ; сброс — чтением регистра данных приемника. 110 — индикатор тайм-аута (за 4-кратный интервал времени символа не передано и не принято ни одного символа, хотя в буфере имеется по крайней мере один). Сброс — чтением регистра данных приемника. 001 — регистр ТНЯ пуст; сброс — записью данных. 000 — изменение состояния модема (CTS, DSR, RI или DCD), сброс — чтением регистра MSR. FCR — регистр управления FIFO (только для записи). Назначение бит регистра FCR: Биты [7:6] — ITL (Interrupt Trigger Level) — уровень заполнения FIFO-буфера, при котором вырабатывается прерывание: 00 - 1 байт (по умолчанию), 01 — 4 байта. 10 - 8 байт. 11 — 14 байт. Биты [5:4] зарезервированы. Бит 3 — разрешение операций DMA. \* Бит 2 — RESETTF (Reset Transmitter FIFO) — сброс счетчика FIFO-передатчика (записью единицы; сдвигающий

регистр не сбрасывается).

10 — принят символ; сброс — чтением данных,

сью данных,

01 — передан символ (регистр *THR* пуст); сброс — запи-

Бит 0 — TRFIFOE (Transmit And Receive FIFO Enable) — разрешение (единицей) режима FIFO для передатчика и приемника. При смене режима FIFO-буферы автоматически очищаются.
 LCR — регистр управления линией (настройки параметров

не сбрасывается).

Бит 1 — RESETRF (Reset Receiver FIFO) — сброс счетчика FIFO-приемника (записью единицы; сдвигающий регистр

- ступом к делителю частоты.

   Бит 6 BRCON (Break Control) формирование обрыва линии (посылка нулей) при BRCON=1.

   Бит 5 STICPAR (Sticky Parity) принудительное форми
  - рование бита паритета:

    0 контрольный бит генерируется в соответствии с паритетом выводимого символа,

    1 постоянное значение контрольного бита: при
  - 1 постоянное значение контрольного бита: при EVENPAR=1 нулевое, при EVENPAR=0 единичное.
     Бит 4 EVENPAR (Even Parity Select) выбор типа контроля: 0 нечетность, 1 четность.
  - Бит 3 PAREN (Parity Enable) разрешение контрольного бита:
     1 контрольный бит (паритет или постоянный) разре-
  - шен,
    0 запрещен.

    Бит 2 *STOPB (Stop Bits)* количество стоп-бит:
  - Бит 2 Зтогь (зюр виз) количество стоп-оит.
     0 1 стоп-бит,
     1 2 стоп-бита (для 5-битного кода стоп-бит будет иметь
  - 1 2 стоп-оита (для 5-оитного кода стоп-оит оудет иметь длину 1,5 бита).
     Биты [1:0] SERIALDB (Serial Data Bits) количество бит
  - данных: 00-5 бит, 01-6 бит, 10-7 бит, 11-8 бит.

# **MCR** — регистр управления модемом. Назначение бит регистра МСР:

Биты [7:5]=0 — зарезервированы.

поступает на вход MSR.7: 0 — прерывания запрещены,

разрещены.

1 -активен (-V), 0 — пассивен (+V).

MSR.4:

88

Бит 4 - LME(Loopback Mode Enable) — разрешение режима диагностики:

0 — нормальный режим,

1 — режим диагностики (см. ниже). Бит 3 - IE (Interrupt Enable) — разрешение прерываний с

сигналом 1 (не используется); в режиме диагностики поступает на вход MSR.6. Бит 1 — RTSC (Request To Send Control) — управление выходом RTS; в режиме диагностики поступает на вход

Бит 0 - DTRC (Data Terminal Ready Control) — управление

помощью внешнего выхода OUT2; в режиме диагностики

Бит 2 - OUT1C(OUT1 Bit Control) - управление выходным

выходом DTR; в режиме диагностики поступает на вход MSR.5: 1 -активен (-V),

0 — пассивен (+V).

LSR — регистр состояния линии (точнее, состояния приемопередатчика). Назначение бит регистра LSR:

Бит 7 - FIFOE (FIFO Error Status) — ощибка принятых данных в режиме FIFO (буфер содержит хотя бы один символ, принятый с ощибкой формата, паритета или обрывом). В не-FIFO-режиме всегда 0.

Бит 6 — TEMPT (Transmitter Empty Status) — регистр передатчика пуст (нет данных для передачи ни в сдвиговом регистре, ни в буферных, THR или FIFO).

FIFO указывает на отсутствие символов в FIFO-буфере передачи. Может являться источником прерывания. Бит 4 - BD (Break Detected) — индикатор обрыва линии (вход приемника находится в состоянии 0 не менее, чем время посылки символа). Бит 3 - FE (Framing Error) — ошибка кадра (неверный стоп-\*\* бит).

Бит 5 - THRE (Transmitter Holding Register Empty) — регистр перелатчика готов принять байт для передачи. В режиме

Бит 2 - PE(Parity Error) - ошибка контрольного бита (па-88 ритета или фиксированного). Бит 1 - OE (Overrun Error) — переполнение (потеря сим-\*\*\* вола). Если прием очередного символа начинается до того,

как предыдущий был выгружен из сдвигающего регист-

- ра в буферный или FIFO, прежний символ в сдвигающем регистре теряется. Бит 0 - DR (Receiver Data Ready) — принятые данные гото-
- вы (в *DHR* или FIFO-буфере). Сброс чтением приемника. Индикаторы ошибок — биты [4:1] — сбрасываются после чтения регистра LSR. В режиме FIFO признаки ощибок хранят-
- устанавливаются (и вызывают прерывание) в тот момент, когда символ, принятый с ошибкой, находится на вершине FIFO (первый в очереди на считывание). В случае обрыва линии в

ся в FIFO-буфере вместе с каждым символом. В регистре они

FIFO заносится только один «обрывной» символ, и UART ждет восстановления и последующего старт-бита. **MSR** — регистр состояния модема.

# Назначение бит регистра MSR:

- Бит 7 DCD (Data Carrier Detect) состояние линии DCD. 883
- Бит 6 RI (Ring Indicator) состояние линии RI.
- Бит 5 DSR(Data Set Ready) cocтояние линии DSR.
- Бит 4 CTS (Clear To Send) состояние линии CTS.
- Бит 3 DDCD (Delta Data Carrier Detect) изменение состояния DCD.
- Бит 2 TERI (Trailing Edge Of Ring Indicator) спад огибающей RI (окончание звонка).

Бит 0 — DCTS (Delta Clear To Send) — изменение состояния СТS.
 Признаки изменения (биты [3:0]) сбрасываются по чтению

ния DSR.

низуется внутренняя заглушка:

состояние (логический ноль).

регистра.

Бит 1 - DDSR (Delta Data Set Ready) — изменение состоя-

- SCR рабочий регистр (8 бит), на работу UART не влияет, предназначен для временного хранения данных (в 8250 отсутствует).
  В диагностическом режиме (при LME=1) внутри UART орга-
- Выход передатчика переводится в состояние логической 1.
   Вход приемника отключается.
   Выход сдвигающего регистра передатчика логически со-
- единяется со входом приемника.

  Входы DSR, CTS, RI и DCD отключаются от входных линий и внутренне управляются битами *DTRC*, *RTSC*, *OUT1C*, *IE*.

  Выходы управления модемом переводятся в пассивное
- Переданные данные в последовательном виде немедленно принимаются, что позволяет проверять внутренний канал данных порта (включая сдвигающие регистры) и отработку

# прерываний, а также определять скорость работы UART.

# **2.5.3. Ресурсы и конфигурирование СОМ-портов** Компьютер может иметь до четырех последовательных портов *COM1–COM4* (для машин класса АТ типично наличие двух портов). COM-порты имеют внешние разъемы-*вилки*

DB25P или DB9P, выведенные на заднюю панель компьютера (назначение выводов приведено в табл. 2.1). СОМ-порты реализуются на микросхемах UART, совместимых с семейством i8250. Они занимают в пространстве вво-

да/вывода по 8 смежных 8-битных регистров и могут располагаться по стандартным базовым адресам. Порты вырабатывают аппаратные прерывания. Возможность разде-

ляемого использования одной линии запроса несколькими

пользовании портов, установленных на шину ISA, разделяемые прерывания обычно не работают. Управление последовательным портом разделяется на два этапа — предварительное конфигурирование (Setup) аппаратных средств порта и текущее (оперативное) переключение

портами (или ее разделения с другими устройствами) зависит от реализации аппаратного подключения и ПО. При ис-

режимов работы прикладным или системным ПО. Конфигурирование СОМ-порта зависит от его исполнения. Порт на плате расширения конфигурируется джамперами на самой плате. Порт на системной плате конфигурируется через BIOS Setup.

Конфигурированию подлежат следующие параметры: Базовый адрес, который может иметь значения 3F8h. 2F8h. 3E8h (3E0h, 338h) или 2E8h (2E0h, 238h). При инициализации BIOS проверяет наличие портов по адресам именно в этом порядке и присваивает обнаруженным

портам логические имена СОМ1, СОМ2, СОМ3 и СОМ4.

Для PS/2 стандартными для портов COM3-COM8 являются адреса 3220h, 3228h, 4220h, 4228h, 5220h и 5228h соответственно. Используемая линия запроса прерывания: для СОМ1 и СОМЗ обычно используется IRQ4 или IRQ11, для СОМ2 и СОМ4 — IRQ3 или IRQ10. В принципе номер прерывания можно назначать в произвольных сочетаниях с базовым адресом (номером порта), но некоторые програм-

мы и драйверы (например, драйверы последовательной мыши) настроены на стандартные сочетания. Каждому порту, нуждающемуся в аппаратном прерывании, назначают отдельную линию, не совпадающую с линиями запроса прерываний других устройств. Прерывания необходимы для портов, к которым подключаются устройства ввода, UPS или модемы. При подключении принтера или

плоттера прерываниями пользуются только многозадачные ОС (не всегда), и этот дефицитный ресурс РС можно сэкономить. Также прерываниями обычно не пользуются при связи двух компьютеров нуль-модемным кабелем.

Режим работы порта по умолчанию (2400 бит/с, 7 бит данных, 1 стоп-бит и контроль четности), заданный при инициализации порта во время BIOS POST, может изменяться в любой момент при настройке коммуникационных программ или командой DOS MODE COMx: с указанием параметров. 2.5.4. Неисправности и тестирование СОМ-портов

Канал DMA (для UART 16450/16550, расположенных на системной плате) — разрешение использования и номер канала DMA. Режим DMA при работе с СОМ-портами

них устройств.

используют редко.

Проверка конфигурирования Тестирование последовательных портов (как и параллельных) начинают с проверки их опознавания системой. Список ад-

Неполадки с СОМ-портами случаются (выявляются) при установке новых портов или неудачном подключении внеш-

ресов установленных портов обычно появляется в таблице, выводимой BIOS перед загрузкой ОС. Список можно посмотреть с помощью тестовых программ или прямо в BIOS Data AREA с помощью отладчика.

Если BIOS обнаруживает меньше портов, чем установлено физически, вероятно, двум портам присвоен один адрес или установлен нестандартный адрес какого-либо порта. Проблемы могут возникать с адресами портов СОМЗ и СОМ4: не все версии BIOS будут искать порты по альтернативным адресам 3E0h, 338h, 2E0h и 238h; иногда не производится

поиск по адресам 3E8h и 2E8h. Нумерация найденных портов, отображаемая в заставке, может вводить в заблуждение: если установлены два порта с адресами 3F8h и 3E8h, в заставке они могут называться СОМ1 и СОМ2, и по этим име-

нам на них можно ссылаться. Однако те же порты в заставке могут называться и СОМ1 и СОМ3 (поскольку 3Е8h является штатным адресом для СОМЗ), но попытка сослать-

ся на порт СОМЗ будет неудачной, поскольку в данном случае адрес 3E8h будет находиться в ячейке 0:402h BIOS Data Area, соответствующей порту COM2, а в ячейке порта COM3 (0:404h) будет нуль — признак отсутствия такового порта.

находить порты (например, Port Finder). Если двум портам назначен один и тот же адрес, тестовая программа обнаружит ошибки порта только с использованием внешней заглушки (External LoopBack). Программное тестирование порта без заглушки не покажет ошибок, поскольку при этом включается диагностический режим (см. описание UART) и конфликтующие (по отдельности ис-

правные) порты будут работать параллельно, обеспечивая совпадение считываемой информации. В реальной жизни нормальная работа конфликтующих портов невозможна. Разбираться с конфликтом адресов удобно, последовательно устанавливая порты и наблюдая за адресами, появляю-

«Объяснить» системе, где какой порт, можно вручную любым отладчиком, занеся правильные значения базовых адресов в ячейки *BIOS Data Area* (это придется делать каждый раз после перезагрузки ОС перед использованием «потерянного» порта). Существуют тестовые утилиты, позволяющие

отключен при конфигурировании, либо вышел из строя. Неисправность может устраниться при вынимании/вставке платы адаптера в слот системной шины. При работе с СОМ-портом задействуются соответствующие аппаратные прерывания — их используют при подключении

Если физически установлен только один порт и его не обнаруживает BIOS, причины те же, что с LPT-портом: либо он

модема, мыши и других устройств ввода. Неработоспособность этих устройств может быть вызвана некорректной настройкой запроса прерывания. Здесь возможны как конфликты с другими устройствами, так и несоответствие номера прерывания адресу порта.

# Функциональное тестироввние

шимися в списке.

В первом приближении СОМ-порт можно проверить диагностической программой (CheckIt) без использования заглушек. Этот режим тестирования проверяет микросхему

UART (внутренний диагностический режим) и вырабатывание прерываний, но не входные и выходные буферные микросхемы, которые являются более частыми источниками неприятностей. Если тест не проходит, причину следует искать или в конфликте адресов/прерываний, или в самой микросхеме UART.

Для более достоверного тестирования рекомендуется исполь-

зовать *внешнюю заглушку*, подключаемую к разъему СОМпорта (рис. 2.17). В отличие от LPT-порта у СОМ-порта количество входных сигналов превышает количество выходных, что позволяет выполнить полную проверку всех цепей.

Заглушка соединяет выход приемника со входом передатчика. Обязательная для всех схем заглушек перемычка RTS-CTS позволяет работать передатчику — без нее символы не смогут передаваться. Выходной сигнал DTR обычно исполь-



**Рис. 2.17.** Заглушка для проверки COM-портов (LoopBack) Если тест с внешней заглушкой не проходит, причину сле-

дует искать во внешних буферах, их питании или в шлейфах подключения внешних разъемов. Здесь может помочь осциллограф или вольтметр. Последовательность проверки может быть следующей:

- Проверить наличие двуполярного питания выходных схем передатчиков (этот шаг логически первый, но поскольку он технически самый сложный, его можно отложить на крайний случай, когда появится желание заменить буферные микросхемы).
- 2. Проверить напряжение на выходах TD, RTS и DTR: после аппаратного сброса на выходе TD должен быть отрицательный потенциал около –12 В (по крайней мере ниже –5 В), а на выходах RTS и DTR такой же положительный. Если этих потенциалов нет, возможна ошибка

шлейф не подключен;
 шлейф подключен неправильно (разъем перевернут или вставлен со смещением);
 раскладка шлейфа не соответствует разъему платы.

подключения разъема к плате через шлейф. Распростра-

ненные варианты:

Первые два варианта проверяются при внимательном осмотре, третий же может потребовать некоторых усилий. В табл. 2.1 приведены три варианта раскладки 10-проводного шлейфа разъема СОМ-порта, известных автору; для СОМ-

портов на системных платах возможно существование и других. Теоретически шлейф должен поставляться в соответствии с разъемом платы, на которой расположен порт. Если дело в ошибочной раскладке, то эти три выходных сигнала удастся обнаружить на других контактах разъе-

Если эти сигналы обнаружить не удалось, очевидно, вышли из строя буферные формирователи.3. Соединив контакты линий RTS и CTS (или установив заглушку), следует попытаться вывести небольшой файл на

мов (на входных контактах потенциал совсем небольшой).

СОМ-порт (например, командой СОРУ С:\AUTOEXEC.ВАТ СОМ1:). С исправным портом эта команда успешно выполнится за несколько секунд с сообщением об успешном копировании. При этом потенциалы на выходах RTS и DTR должны измениться на отрицательные, а на выхо-

и DTR должны измениться на отрицательные, а на выходе TD должна появиться пачка двуполярных импульсов с амплитудой более 5 В. Если потенциалы RTS и DTR не изменились, ошибка в буферных формирователях. Если на выходе RTS (и входе CTS) появился отрицательный потенциал, а команда СОРУ завершается с ошибкой, ско-

изменились, ошибка в буферных формирователях. Если на выходе RTS (и входе CTS) появился отрицательный потенциал, а команда *COPY* завершается с ошибкой, скорее всего, вышел из строя приемник линии CTS (или опять-таки ошибка в шлейфе). Если команда *COPY* успешно проходит, а изменения на выходе TD не обнаруживаются (их можно увидеть стрелочным вольтметром,

но оценить амплитуду импульсов не удастся), виноват

буферный передатчик сигнала TD.

монту не подлежит (по крайней мере в обычных условиях). Неисправный СОМ-порт, установленный на системной плате, можно попытаться отключить в BIOS SETUP, но порт мог сгореть и вместе со схемой своего отключения - тогда он останется «живым мертвецом» в карте портов ввода/вывода и прерываний. Иногда он полностью выводит из строя системную плату. Источниками ошибок могут являться разъемы и кабели.

Замена микросхем приемников и передатчиков существенно облегчается, если они установлены в «кроватки». Перед заменой следует с помощью осциллографа или вольтметра удостовериться в неисправности конкретной микросхемы. Расположение выводов микросхем приведено на рис. 2.6. Если буферные элементы включены в состав интерфейсной БИС (что теперь весьма распространено), то такой порт ре-

В разъемах встречаются плохие контакты, а кабели кроме возможных обрывов могут иметь плохие частотные характеристики. Частотные свойства кабелей обычно сказываются при большой длине (десятки метров) на высоких скоростях обмена (56 или 115 Кбит/с). При необходимости использования длинных кабелей на высоких скоростях сигнальные провода данных должны быть перевиты с отдельными проводами «схемной земли».

# Питание от интерфейса, или Почему может не работать мышь

гопотреблением возникает соблазн использования питания от выходных линий интерфейса. Если линии управления DTR и RTS не используются по прямому назначению, их можно задействовать как питающие с напряжением около 12 В. Ток короткого замыкания на «схемную землю» ограничен буферной микросхемой передатчика на уровне 20 мА. При инициализации порта эти линии переходят в состояние «выключено», то есть вырабатывают положительное напряжение. Линия

При подключении к СОМ-порту устройств с небольшим энер-

TD в покое находится в состоянии логической единицы, так что на выходе вырабатывается отрицательное напряжение. Потенциалами линий можно управлять через регистры СОМпорта (выход ТО вырабатывает положительное напряжение, если установить бит BRCON).

от порта выходного напряжения не менее 5 В (абсолютного значения), и, если данный порт обеспечивает только этот минимум, некоторым мышам не хватит мощности для питания светодиодов (главных потребителей энергии).
Порт получает двуполярное питание через системную плату от блока питания компьютера. Отсутствие на выходе блока

питания напряжения +12 В обычно обнаружится по неработоспособности дисков. Отсутствие напряжения –12 В «заметят» только устройства, подключенные к СОМ-портам. Блок питания теоретически контролирует наличие этих на-

Двуполярным питанием от линий интерфейса (+V от DTR и RTS, -V от TD) пользуются все манипуляторы, подключаемые к СОМ-портам. Зная это, в случае неработоспособности мыши с данным портом следует проверить напряжения на соответствующих контактах разъема. Бывает, что с конкретным портом не работает только конкретная мышь (модель или экземпляр), хотя другие мыши с этим портом и эти же мыши с другими портами работают нормально. Здесь дело может быть в уровнях напряжений. Стандарт требует

пряжений на своем выходе (сообщая о неполадках сигналом Power Good, вызывающим аппаратный сброс). Встречаются упрощенные схемы блоков питания, у которых контролируются не все напряжения. Кроме того, возможны плохие контакты в разъеме подключения питания к системной плате.

# 2.5.5. Функции BIOS для COM-портов

В процессе начального тестирования POST BIOS проверяет наличие последовательных портов (регистров UART 8250 или совместимых) по стандартным адресам и помещает базовые адреса обнаруженных портов в ячейки *BIOS Data Area* 0:0400, 0402, 0404, 0406. Эти ячейки хранят адреса пор-

тов с логическими именами *COM1–COM4*. Нулевое значение адреса является признаком отсутствия порта с данным номером. В ячейки 0:047С, 047D, 047E, 047F заносятся константы, задающие тайм-аут для портов.

Обнаруженные порты *инициализируются* на скорость обмена 2400 бит/с, 7 бит данных с контролем на четность

и RTS переводятся в исходное состояние («выключено» — положительное напряжение).
Порты поддерживаются *сервисом BIOS INT 14h*, который обеспечивает следующие функции:

(even), 1 стоп-бит. Управляющие сигналы интерфейса DTR

№ 00h — инициализация (установка скорости обмена и формата посылок, заданных регистром AL; запрет источников прерываний). На сигналы DTR и RTS влияния не ока-

01h — вывод символа из регистра AL (без аппаратных прерываний). Активируются сигналы DTR и RTS, и после

зывает (после аппаратного сброса они пассивны).

- освобождения регистра *THR* в него помещается выводимый символ. Если за заданное время регистр не освобождается, фиксируется ошибка тайм-аута и функция завершается.

  © 2h ввод символа (без аппаратных прерываний). Акти-
- вируется только сигнал DTR (RTS переходит в пассивное состояние), и ожидается готовность принятых данных, принятый символ помещается в регистр AL. Если за заданное время данные не получены, функция завершается с ошибкой тайм-аута.

03h — *опрос состояния* модема и линии (чтение регист-

- ров *MSR* и *LSR*). Эту гарантированно быструю функцию обычно вызывают перед функциями ввода/вывода во избежание риска ожидания тайм-аута.

  При вызове *INT 14h* номер функции задается в регистре *AH*, номер порта (0-3) в регистре *DX* (0 *COM1*, 1 *COM2*...).
- номер порта (0-3) в регистре *DX* (0 *COM1*, 1 *COM2*...). При возврате из функций 0, 1 и 3 регистр *AH* содержит *байт* состояния линии (регистр *LSR*), *AL байт* состояния модема (MSR). При возврате из функции 2 нулевое значение бита 7 регистра *AH* указывает на наличие принятого символа в регистре *AL*; ненулевое значение бита 7 на ошибку приема, которую можно уточнить функцией 3.

# Формат байта состояния линии (регистр AH):

признак любой ошибки).

Бит 7— ошибка тайм-аута (после вызова функции 2

- Бит 6 регистр сдвига передатчика пуст (пауза передачи). 88 Бит 5 — промежуточный регистр передатчика пуст (го-88 тов принять символ для передачи). Бит 4 — обнаружен обрыв линии. 88 Бит 3 - ошибка кадра (отсутствие стоп-бита).Бит 2 — ошибка паритета принятого символа. 88 Бит 1 — переполнение (потеря символа). 88 Бит 0 — регистр данных содержит принятый символ. Формат байта состояния модема (регистр AL): Бит 7 — состояние линии DCD. Бит  $6 - \cos$  линии Rl. Бит 5 — состояние линии DSR. 88 Бит 4 — состояние линии CTS. Бит 3 — изменение состояния DCD. 88 Бит 2 — изменение огибающей RI. 332
  - Бит 0 изменение состояния СТЅ.
     Формат регистра АІ при инициализации:
     Биты [7:5] скорость обмена:

Бит 1 — изменение состояния DSR.

88

- 11 четное, 00 и 10 — без контроля. Вит 2 — количество стоп-бит: 0 — 1 бит, 1 — 2 бита (ур. сургажду 110 бут (а. . . 1.5 стор бута))
  - Бит 2 количество стоп-оит. 0 1 оит, 1 2 оита (на скорости 110 бит/с 1,5 стоп-бита).
     Биты [1:0] длина посылки: 00 5 бит, 01 6 бит, 10 7 бит, 11 8 бит.

# 2.5.6. СОМ-порт и РпР

Современные ПУ, подключаемые к СОМ-порту, могут поддерживать спецификацию PnP. Основная задача ОС заключается в идентификации подключенного устройства, для чего разработан несложный протокол, реализуемый на любых СОМ-портах чисто программным способом (рис. 2.18):



Рис. 2.18. Запрос идентификатора устройства РпР

- 1. Порт инициализируется с состоянием линий DTR=ON, RTS=OFF, TXD=Mark состояние покоя (Idle).
- 2. Некоторое время (0,2 с) ожидается появление сигнала DSR, которое указало бы на наличие устройства, подключенного к порту. В простейшем случае устройство имеет на разъеме перемычку DTR-DSR, обеспечивающую указанный ответ. Если устройство обнаружено, выполняются манипуляции управляющими сигналами DTR и RTS для получения информации от устройства. Если ответ не получен, ОС, поддерживающая динамическое реконфигурирование, периодически опрашивает состояние порта для обнаружения новых устройств.
- 3. Порт программируется на режим 1200 бит/с, 7 бит данных, без паритета, 1 стоп-бит, и на 0,2 с снимается сигнал DTR. После этого устанавливается DTR=1, а еще через 0,2 с устанавливается и RTS=1.
- 4. В течение 0,2 с ожидается приход первого символа от устройства. По приходе символа начинается прием идентификатора (см. ниже). Если за это время символ не пришел (рис. 2.18), выполняется вторая попытка опроса (см. п. 5), несколько отличающаяся от первой.
- 5. На 0,2 с снимаются оба сигнала (DTR=0 и RTS=0), после чего они оба устанавливаются (DTR=1 и RTS=1).

фикатора (см. ниже). Если за это время символ не пришел, то в зависимости от состояния сигнала DSR переходят к проверке отключения *Verify Disconnect* (при DSR=0) или в дежурное состояние *Connect Idle* (при DSR=1).

7. В дежурном состоянии *Connect Idle* устанавливается DTR=1, RTS=0, порт программируется на режим 300 бит/с, 7 бит данных, без паритета, 1 стоп-бит. Если в этом состоянии обнаружится DSR=0, ОС следует уведомить об

В течение 0,2 с ожидается приход первого символа от устройства, по приходе символа начинается прием иденти-

- отключении устройства. Посимвольный прием идентификатора устройства имеет ограничения по тайм-ауту в 0,2 с на символ, а также общее ограничение в 2,2 с, позволяющее принять строку длиной до 256 символов. Строка идентификатора PnP должна иметь маркеры начала (28h или 08h) и конца (29h или 09h), между которыми располагается тело идентификатора в стандарти-
- зованном формате. Перед маркером начала может находиться до 16 символов, не относящихся к идентификатору PnP. Если за первые 0,2 с ожидания символа (шаг 4 или 6) маркер начала не пришел, или же сработал тайм-аут, а маркер конца не получен, или же какой-либо символ принят с ошибкой, происходит переход в состояние Connect Idle. Если получена корректная строка идентификатора, она передается ОС.
- ректная строка идентификатора, она передается ОС. Для проверки отключения (Verify Disconnect) устанавливается DTR=1, RTS=0 и через 5 с проверяется состояние сигнала DSR. При DSR=1 происходит переход в состояние Connect Idle (см. п. 7), при DSR=0 происходит переход в состояние Disconnect Idle, в котором система может периодически опрашивать сигнал DSR для обнаружения подключения уст
- опрашивать сигнал DSR для обнаружения подключения устройства.

  Описанный механизм разрабатывался фирмой Microsoft с учетом совместимости с не-PnP-устройствами невозможность их вывода из строя и устойчивость системы к сообщениям, не являющимся PnP-идентификаторами. Например, обычная Microsoft Mouse при включении питания от интер-

фейса ответит ASCII-символом «М» (трехкнопочная — стро-

кой «МЗ»).

# 3. Специальные интерфейсы

В этой главе рассматриваются следующие интерфейсы IBM PC-совместимых компьютеров: интерфейсы устройств ввода (клавиатуры и манипуляторов), аналоговый и дискретный интерфейсы игрового адаптера, аудиоинтерфейсы и интерфейсы мониторов.

Для подключения клавиатуры предназначен последовательный синхронный интерфейс, состоящий из двух обязательных сигналов, KB-Data и KB-Clock. Необязательный сигнал

# 3.1. Интерфейс клавиатуры

КВ-Reset сбрасывает клавиатуру низким уровнем сигнала. Интерфейс на системной плате XT реализован аппаратной логикой — регистром сдвига, параллельный выход которого подключается ко входам порта А системного интерфейса i8255. По приему байта от клавиатуры вырабатывается аппаратное прерывание IRQ2, обработчик которого может прочитать принятый байт из порта 60h. С помощью бит 7 и 6 порта 61h возможны программная блокировка и сброс клавиатуры соответственно. Сброс клавиатуры XT осуществляется обнулением линии KB-Clock.

Интерфейс клавиатуры АТ построен на микроконтроллере

интерфейс с клавиатурой. Передача информации к клавиатуре используется для управления индикаторами ее состояния и программирования параметров (автоповтор, набор скан-кодов).

Хотя электрический интерфейс клавиатур ХТ и АТ совпадает (за исключением двунаправленного обмена в АТ), ло-

і8042, обеспечивающем, в отличие от ХТ, двунаправленный

дает (за исключением двунаправленного обмена в АТ), логические форматы посылок существенно отличаются. POST способен производить диагностику клавиатуры. Подключение клавиатуры неподходящего типа или отсутствие клавиатуры он воспримет как ошибку. Если проверка клавиатуры

разрешена в BIOS Setup, то по этой ошибке POST будет дожидаться получения кода клавиши F1.
Вид разъемов клавиатур (со стороны задней панели) и назна-

чение контактов приведены на рис. 3.1. Конструктивно возможны два варианта разъема — обычная 5-контактная розетка

DIN или малогабаритная розетка mini-DIN (PS/2). На этот же разъем через плавкий предохранитель поступает напряжение питания клавиатуры +5 В. Электрически и логически интерфейс клавиатуры PS/2 повторяет АТ, поэтому для согласования типа разъема применяют специальные переходники. Предпочтительнее использовать переходники, выполненные в виде мягкого кабеля с разъемами. Монолитный переходник, особенно с АТ-клавиатуры на PS/2-разъем, хуже тем, что

малейшее движение кабеля вызывает большой момент силы, выламывающий переходник из маленького гнезда PS/2.



(вид со стороны контактов)

Питание от разъема клавиатуры часто используется такими устройствами, как внешние накопители или адалтеры локальных сетей, подключаемыми к параллельному порту. Плавкий предохранитель, установленный на системной плате, может не вы-

держать броска тока, потребляемого этими устройствами. При этом откажется работать и клавиатура — ее индикаторы не мигнут при включении.

Программириемый микроконтроллер i8042 имеет встроенное

Программируемый микроконтроллер i8042 имеет встроенное ПО, которое хранится в масочном внутреннем ПЗУ и обес-

ПО, которое хранится в масочном внутреннем ПЗУ и обеспечивает вырабатывание запроса прерывания по приему скан-

кода от клавиатуры и отработку управляющих команд от ЦП. Кроме управления клавиатурой, через программно-управляемые и программно-читаемые линии внешних пор-

управляемые и программно-читаемые линии внешних портов контроллера формируются сигналы управления вентилем *Gate A20*, аппаратного системного сброса, а также считываются сигналы от конфигурационных джамперов системной платы. Контроллер i8242B, кроме интерфейса кла-

Порт ввода, доступный по команде C0h, используется для чтения состояния джамперов и ключа: Бит 7 — если 0, то клавиатура заблокирована ключом (KeyLock). Бит 6 — исходный видеорежим: 0=CGA, 1=MDA. Бит 5 — системная перемычка: 0=замкнута. 88 Бит 4 — системное O3У: 0=512 Кбайт и более, 1=256 Кбайт. Бит 1 — вход данных дополнительного интерфейса. Бит 0 — вход данных интерфейса клавиатуры.

виатуры, поддерживает аналогичный интерфейс дополнительного устройства, например PS/2-Mouse. Контроллер имеет два порта, доступ к которым осуществляется через

команды контроллера.

Порт вывода, доступный для записи и чтения по командам D1h и D0h соответственно, имеет следующее назначение бит:

Бит 7 — последовательные данные клавиатуры.

Бит 6 — синхронизация клавиатуры.

Бит 5 — запрос прерывания от дополнительного интерфейса (IRQ12).

Бит 4 — запрос прерывания от клавиатуры (IRQ1). Бит 3 — синхронизация дополнительного интерфейса. 88

Бит 2 — последовательные данные дополнительного интерфейса.

Бит 1 — вентиль линии адреса A20 (*Gate A20*). Бит 0 — альтернативный сброс процессора (без формирования общего сигнала сброса).

Контроллер расположен в пространстве ввода/вывода по адресам 60h и 64h, причем по чтению скан-кода клавиату-

ры из порта 60h сохраняется совместимость с ХТ. Назначение регистров контроллера клавиатуры приведено в табл. 3.1. Регистр данных контроллера в режиме записи используется для подачи команд, относящихся к клавиатуре и собственно контроллеру. Признаком готовности контроллера является

нулевое значение бита 1 регистра состояния (порт 064h).

### Таблица 3.1. Назначение регистров контроллера клавиатуры

Назначение

Порт,

| R/W        | nasna-cnac                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
|------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 060 RW     | Порт данных 8042                                                                                                                                                                                                                                                                                                                                                                                                                                              |
| 064 R      | Регистр состояния 8042:  Бит 7 — оппибка четности  Бит 6 — тайм-аут приемника/общий тайм-аут*  Бит 5 — тайм-аут передатчика/выходной буфер дополнительного интерфейса полон*  Бит 4: 1 — клавиатура на замке  Бит 3:     1 — команда,     0 — данные  Бит 2:     0 — Power ON,     1 — Reset OK (состояние завершения     системного сброса)  Бит 1:     1 — входной буфер полон,     0 — готовность к приему команды/данных  Бит 0: 1 — выходной буфер полон |
| 064 W      | Регистр команд 8042                                                                                                                                                                                                                                                                                                                                                                                                                                           |
| * Второе н | азначение бита относится к контроллеру і8242В, имеющем                                                                                                                                                                                                                                                                                                                                                                                                        |

<sup>\*</sup> Второе назначение бита относится к контроллеру i8242B, имеющему дополнительный интерфейс для подключения PS/2-Mouse.

### Общие команды контроллера i8042:

- DF разрешить управление линией A20.

- В размен в порт вывода 18042.
   № ро чтение порта вывода 18042.
- \*\* AE разрешение клавиатуры.\*\* AD запрещение клавиатуры.

**AB** — тест синхронизации и данных. 88 **АА** — внутренний тест контроллера. **60** — запись в контроллер. 20 — чтение контроллера. 88 Команды иправления клавиатирой АТ: FF - Reset - сброс и тест клавиатуры.FE — Resend — повтор последней передачи. \* FB-FD — Set Key Types — установка автоповтора отдельных клавиш. F7-FA — Set All Keys — установка операции автоповтора клавиатуры. F6 — Set Default — сброс в начальное состояние и разре-88 шение сканирования. F5 — Default Disable — сброс в начальное состояние и запрет сканирования. F4 — Enable KB — клавиатура ответит байтом подтверж-88 дения АСК и продолжит сканирование. F3 — Set Typematic Rate/Delay — задание задержки и частоты повтора кодов. Последующий байт данных имеет следующий формат: Бит 7=0. Биты [6:5] — задержка, мс: 00=250, 01=500, 10=750, 11=1000. Биты [4:0]=00-1Fh — скорость повторов, 1/с: 00h=30.0 05h=18,5 0Ah=12.0 12h=6.001h=26.706h=17,1 0Ch=10,0 14h=5,0 07h=16,0 0Dh=9,2 17h=4,0 02h=24.003h=21,8 08h=15.0 0Fh=8.0 1Ah=3.0 04h=20.009h=13,3 10h=7,5 1Fh=2,0 F2 - Read ID Code - запрос на двухбайтный идентификатор. EE - Echo - эхо-диагностика: возвращает 0EEh.

ED - Set/Reset Mode Indicators - управление индикато-

рами клавиатуры. Последующий байт данных:

Бит 0: 1=включить Scroll Lock. Бит 1: 1=включить Num Lock. Бит 2: 1=включить Caps Lock. *AD* — запрет сканирования.

- Из регистра данных контроллера кроме скан-кодов возможно получение ответов на команды, префикса кода отпускания клавиши (*FO*) или кодов особых случаев:

  « *FA ACK* подтверждение приема команды.
  - AA Test OK внутренний тест прошел.
- st FD Diagnostic Failure ошибка внутреннего теста.
- *EE* − *Echo Response* − ответ на эхо-команду.
- 00, FF Buffer Error переполнение буфера или неидентифицированная клавиша.

## 3.2. Интерфейсы манипуляторов

мацию о своем перемещении и нажатии-отпускании кнопок. Обычная конструкция имеет свободно вращающийся массивный обрезиненный шарик, передающий вращение на два координатных диска с фотоэлектрическими датчиками — две открытые оптопары (светодиод — фотодиод), в оптический

Устройство ввода мышь (mouse) передает в систему инфор-

По интерфейсу с компьютером различают три основных вида мышей: *Bus Mouse, Serial Mouse* и *PS/2-Mouse*. Ожидается появление мышей с интерфейсом USB.

канал которых входит вращающийся диск с прорезями.

Bus Mouse (шинная мышь) — вариант, применявшийся в первых мышах. Содержит только датчики и кнопки; обработка их сигналов производится на специализированной плате адаптера. Муль-

типортовые карты (COM-, LPT- и GAME-порты), на которых установлен и адаптер Bus Mouse, встречаются редко. Кабель 9-проводный, разъем специальный (см. рис. 3.2 и табл. 3.2), хотя на первый взгляд напоминает разъем PS/2-Mouse.

### Таблица 3.2. Разъем Bus Mouse

| Контакт | Сигналы       | Контакт | Сигналы             |
|---------|---------------|---------|---------------------|
| 1       | Vcc (+5 B)    | 6       | Lb — левая кнопка   |
| 2       | Xa — датчик X | 7       | Mb — средняя кнопка |
| 3       | Xb — датчик X | 8       | Rb — правая кнопка  |
| 4       | Ya — датчик Y | 9       | GND                 |
| 5       | Yb — датчик Y |         |                     |



Рис. 3.2. Разъем Bus Mouse

Serial Mouse — мышь с последовательным интерфейсом, подключаемая через 25 или 9-штырьковый разъем СОМ-порта (табл. 2.3). Имеет встроенный микроконтроллер, который обрабатывает сигналы от координатных датчиков и кнопок. Каждое событие кодируется двоичной посылкой по интерфейсу RS-232C (см. 2.5.1).

PS/2-Mouse — мышь, появившаяся с компьютерами PS/2. Ее интерфейс и 6-штырьковый DIN мини-разъем аналогичны клавиатурному (рис. 3.3). Адаптер и разъем PS/2-Mouse устанавливается на современных системных платах brandname. Контроллер такой мыши может входить в контроллер клавиатуры или занимать дополнительные адреса в пространстве ввода/вывода. Для PS/2-Mouse используется



Рис. 3.3. Разъем PS/2-Mouse

линии. Ясно, что совместимости между этими интерфейсами нет. Тем не менее, выпускаются и продаются переходники (пассивные!), позволяющие выбирать способ подключения мыши. Они предназначены только для универсальных мышей, у ко-

торых встроенный контроллер по напряжению питания способен распознать, к какому интерфейсу его подключили, и установить соответствующий тип своего выходного интерфейса. Универсальные мыши не особо распространены, поэтому часто приходится слышать о неудачных попытках применения таких переходников к обычным Serial Mouse или

С интерфейсами Serial Mouse и PS/2-Mouse иногда возникают недоразумения. Хотя оба они последовательные, но имеют принципиальные различия в уровнях сигналов, спо-

Интерфейс PS/2 использует однополярный сигнал с уровнями ТТЛ, питание мыши — однополярное с напряжением +5 В относительно шины GND. Интерфейс RS-232C, применяемый в Serial Mouse, использует двухполярный сигнал (см. 2.1.1) с уровнями срабатывания +3 В

Синхронный интерфейс PS/2-Mouse использует две раздельные сигнальные линии, одну — для передачи данных, другую — для сигналов синхронизации. Serial Mouse использует асинхронный способ передачи данных по одной

собе синхронизации, частоте и формате посылок:

и -3 В, требует двухполярного питания.

PS/2-Mouse.

Macintosh, которые имеют разъем, с виду напоминающий PS/2. Однако разъемы эти разные, да и интерфейс совершенно иной.

Манипулятор трекбол (trackball) («шар») представляет со-

Дополнительную путаницу вносят мыши для компьютеров

бой перевернутую мышь, шарик которой вращают пальцами. Иногда встраивается в клавиатуру.

3.3. Интерфейс игрового адаптера — GAME-порт

3.3. Интерфейс игрового адаптера — GAME-порт Интерфейс игрового адаптера занимает особое место в клас-

сификации. Он позволяет вводить значения дискретных

ков. Метод измерения сопротивления основан на программном определении длительности импульса, пропорциональной сопротивлению. Преобразование начинается по выводу любого байта в регистр адаптера (201h), при этом биты 0-3 устанавливаются в 1. Время измеряется до возврата в нулевое состояние бит 0-3, соответствующих четырем аналоговым каналам. Если аналоговый вход закорочен на шину GND

(4 бита) и аналоговых сигналов (сопротивления 4 резисторов). Изначально порт был предназначен для подключения джойстиков и других игровых устройств ввода (Paddle), но может применяться и для подключения «серьезных» датчи-

или цень измеряемого сопротивления разорвана, соответствующий бит не обнулится. Поэтому в программе преобразования должен быть предусмотрен тайм-аут. Для измеряемых сопротивлений в диапазоне 0-100 кОм время определяется по формуле  $T = 24.2 + 11 \times R$ где T — время (в микросекундах), а R — сопротивление (в ки-

лоомах).

Точность и линейность преобразования невысока, преобразование выполняется не быстро (до 1,12 мс) и сильно загружает процессор. Однако в отличие от «настоящих» аналогоцифровых преобразователей этот достается даром — игровой карт или системных плат.

адаптер входит в состав практически всех комбинированных плат последовательных и параллельных портов, звуковых Порт имеет разъем-розетку DB-15S. Назначение выводов и соответствие сигналов битам регистра приведены в табл. 3.3. Резисторы подключаются к шине питания +5 В, кнопки — к шине GND (рис. 3.4). Замыканию кнопок соответствуют нули

дискретного ввода, если их входы подключить к кнопкам, замыкающим их на шину GND, и к резисторам, «подтягивающим» их к уровню + 5 В. Два джойстика (А и В) подключаются через Ү-образный переходник-разветвитель. На звуковых картах через разъем «Game» вместе с джойстиками

в битах 5-7. Аналоговые каналы можно использовать для

могут подключаться и внешние MIDI-устройства через спепиальный кабель-адаптер, обеспечивающий гальваническую рис. 2.16). Для интерфейса MIDI используются контакты 12 и 15, ранее предназначавшиеся для шин GND и +5V. Такое назначение делает безопасным подключение адаптера MIDI к «чистому» игровому порту и обычного джойстика к игровому порту с сигналами MIDI.

развязку входного сигнала и ограничение выходного тока (см.



Рис. 3.4. Подключение датчиков к игровому адаптеру

Таблица 3.3. Интерфейс игрового адаптера и МЮ

| Бит | Назначение                          | Контакт       |
|-----|-------------------------------------|---------------|
| 7   | Джойстик В кнопка #2                | 14            |
| 6   | Джойстик В кнопка #1                | 10            |
| 5   | Джойстик А кнопка #2                | 7             |
| 4   | Джойстик А кнопка #1                | 2             |
| 3   | Джойстик В Ү-координата             | 13            |
| 2   | Джойстик В X-координата             | 11            |
| 1   | Джойстик А Ү-координата             | 6             |
| 0   | Джойстик A X-координата             | 3             |
| _   | GND                                 | 4, 5, (12)    |
| _   | +5 B                                | 1, 8, 9, (15) |
|     | MIDI-Rx — вход (на звуковой карте)  | 15            |
| _   | MIDI-Tх — выход (на звуковой карте) | 12            |

# 3.4. Аудиоинтерфейсы

диционный канал управления звуком (PC Speaker) представлял собой примитивный синтезатор. Теперь для звуковоспроизведения (и звукозаписи) используется ставший стандартным двунаправленный цифровой аудиоканал. Роль PC Speaker сводится к подачам гудков при загрузке, идентификации ошибок во время POST, а также к сопровождению сообщений об ошибках.

В первых РС этот интерфейс был однонаправленным — тра-

# 3.4.1. PC Speaker

Стандартный канал управления звуком PC Speaker рассчитан на подключение высокоомного малогабаритного динамика. Логическая схема канала приведена на рис. 3.5. Звук формируется из тонального сигнала от второго канала системного таймера, которым можно программно управлять. Частоту сигнала можно изменять, программируя коэффициент деления счетчика-таймера, который расположен в пространстве ввода/вывода по адресу 042h. При записи (и чтении) 16-битный двоичный код передается парой (обязательно!) 8-битных операций (сначала младший байт, потом старший). Разрешая/запрещая формирование сигнала программно-управляемым битом 0 системного порта 61h, можно подавать сигналы определенной длительности. Такой способ формирования звука не загружает процессор и позволяет исполнять незамысловатые мелодии. С учетом инерции слуха быстрым переключением частот можно достигать эффекта

многоголосия. Более интересные звуки можно извлекать, используя принцип широтно-импульсной модуляции, программно осуществляемой через бит 1 порта 61h. В этом случае динамик выполняет роль фильтра низких частот (инерционного звена) демодулятора. Процессоры, начиная с 80286, способны формировать поток управляющих сигналов, который позволяет воспроизводить музыкальный или речевой сигнал с качеством карманного радиоприемника. Однако такое формирование звука практически полностью загружает процессор. Качество воспроизведения сильно зависит от частотных

свойств динамика. Предпочтительнее более крупные динамики, у которых лучше воспроизведение нижних частот, — с ними можно добиться даже разборчивости речи. Драйвер для звукоизвлечения существует также и для Windows 3.x/95, но в стандартную поставку Windows не входит.



Рис. 3.5. Канал управления звуком

### 3.4.2. Цифровой аудиоканал

Кроме стандартного канала управления звуком, фактически стандартизованными являются средства работы с аудиосигналом, имеющиеся на плате Sound Blaster фирмы Creative Labs (табл. 3.4). Звуковые карты обычно имеют 16-битную шину ISA (8-битные нежелательны), РСІ или РС Card, новые модели поддерживают PnP. Звуковая карта в своем составе имеет цифровой канал записи-воспроизведения моно- и стереофонического сигнала, микшер, синтезатор и MIDI-порт.

Цифровой аудиоканал обеспечивает возможность моно- или стереофонической записи и воспроизведения аудиофайлов с уровнем качества от кассетного магнитофона до аудио-СD. Запись производится оцифровкой сигнала с частотой дискретизации 5-44,1 кГц. Разрядность используемых АДС и DAC (аналого-цифровых и цифроаналоговых преобразователей) варьируется от 8 до 16 бит. Более совершенные схемы имеют встроенные средства компрессии сигнала, например, по методу адаптивной дельта-импульсно-кодовой модуляции (ADPCM). В этом случае в цифровом виде хранятся не значения выборок, а специальным образом обработанные разности величин соседних выборок, что позволяет (при сохранении качества) значительно уменьшить объем записи. Компрессия аудиосигнала применяется, например, в кодеках MPEG и голосовых модемах. На стандартных аудио-CD компрессия не применяется.

Для передачи потока данных по шине в цифровой аудиоканал и обратно используются 8- и/или 16-битные каналы DMA. Звуковой канал использует аппаратные прерывания и порты ввода/вывода. Для организации телефонной связи по сети (например, IPhone) нужен полнодуплексный режим (Full Duplex), реализуемый далеко не на всех картах.

### Таблица 3.4, Назначение регистров Sound Blaster 16

| Адрес*      | R/W | Назначение                         |
|-------------|-----|------------------------------------|
| SB+0 (388h) | R   | FM music status                    |
| SB+0 (388h) | w   | FM music address register          |
| SB+1 (389h) | W   | FM music data register             |
| SB+2 (38Ah) | w   | Advanced FM music address register |
| SB+3 (38Bh) | w   | Advanced FM music data register    |
| SB+4        | W   | Mixer, I/O setup address register  |
| SB+5        | R/W | Mixer, I/O setup data register     |
| SB+6        | W   | DSP reset                          |
| SB+8        | W   | FM music address register          |
| SB+9        | W   | FM music data register             |
| SB+0Ah      | R   | DSP read data                      |
| SB+0Ch      | W   | DSP write data or command          |
| SB+0Ch      | R   | DSP write buffer status            |
| SB+0Dh      | R   | DSP timer interrupt clear          |
| SB+0Eh      | R   | DSP data available status          |
| SB+0Fh      | R   | 16-bit voice interrupt clear       |
| SB+(10h13h) |     | Reserved                           |
| MPU+0       | R/W | MPU-401 data                       |
| MPU+1       | R   | MPU-401 status                     |
| MPU+1       | W   | MPU-401 command                    |

<sup>\* 38</sup>xh — адреса регистров FM music для плат Adlib. SB — базовый адрес Sound Blaster (220h, 240h, 260h, 280h).

MPU — базовый адрес MIDI-порта (300h, 330h).

вести на экран подобие осциллограмм записанных сигналов.

Микшер с программным управлением обеспечивает регулировку входных и выходных сигналов, а также настройку тембра по низким и высоким частотам. Микшер позволяет сме-

шивать входные сигналы от нескольких источников.

Оцифрованный звук хранится в файлах. Размер файла зависит от длительности записи, разрядности преобразования, частоты квантования и количества каналов (моно или стерео). Эти файлы редактируются ПО, которое позволяет вы-

Синтезатор обеспечивает имитацию звучания музыкальных инструментов и воспроизведение различных звуков. В звуковых картах в основном используют два метода синтеза — частотный и волновой.

FM Music Synthesizer — синтезатор с частотной модуляцией (Frequency Modulated) имеет несколько каналов (голосов).

Каждый канал содержит несколько синусоидальных генераторов (операторов), управляющих параметрами (частота, амплитуда) друг друга. Частотный синтезатор при небольшом числе операторов не обеспечивает хорошего синтеза.

Более совершенные платы имеют WT Music Synthesizer — синтезаторы на основе таблицы волн (Wave Table) — их на-

зывают также волновыми синтезаторами, — хранящие в своей постоянной памяти образцы некоторых звуков натуральных инструментов. При воспроизведении звука выходной сигнал пересчитывается встроенным процессором на соответствующие параметры частоты и амплитуды. Для хранения большего количества образцов возможна установка ОЗУ. Волновые синтезаторы обеспечивают высокое качество синтеза.

Для подключения внешних МІDІ-устройств звуковые кар-

ты имеют порт MIDI (Musical Instrument Device Interface). Интерфейс — токовая петля с питанием от передатчика и гальванической развязкой входных цепей приемника (см.

главу 2) — выведен на контакты 12, 15 разъема игрового адаптера. Обычно MIDI-порт эмулирует UART MPU-401, использующий два порта ввода/вывода и прерывание.

Звуковая карта имеет набор разъемов для подключения внешних сигналов (входные — микрофон, линейный вход, CD-ROM; выходные — линейный выход, выход на колонки или наушники), некоторые платы имеют цифровой вход от CD-ROM. Встроенный усилитель имеет мощность до 4 Вт на канал. Колонки (Speakers) для РС имеют специальный магнитный экран или улучшенную конструкцию магнитной системы динамиков, чтобы предотвратить воздействие магнитного поля на монитор. Активные колонки (Active Speakers) имеют встроенный усилитель и требуют внешнего питания. Полоса частот колонок РС недостаточна для Ні-Гі воспроизведения. Более качественные системы имеют две колонки для средних и высоких частот и одну большую (сабвуфер) — для низких.

Иля выдачи MIDI-команд существуют специальные MIDI-

Для создания специальных эффектов (хор, реверберация и т. п.) на более сложных звуковых картах применяются процессоры обработки сигналов DSP (Data Signal Processor).

тепиано и других инструментов. MIDI-интерфейс имеют многие профессиональные и полупрофессиональные клавишные синтезаторы. Подключение к звуковой карте внешних устройств осуществляется через малогабаритные стереоразъемы — «джеки» (jack) — на задней панели:

клавиатуры, простейшие фиксируют и передают только факт нажатия-отпускания клавиш, более сложные имеют динамические датчики, реагирующие на силу и скорость нажатия. Динамическая клавиатура в сочетании с хорошим WT-синтезатором обеспечивает достаточно полную имитацию фор-

Line In — линейный вход от магнитофона, тюнера, проигрывателя, синтезатора и т. п. Чувствительность порядка 0,1-0,3 В.

ка 0,1-0,3 В. *Міс Іп* — микрофонный вход, чувствительность 3-10 мВ. *Line Out* — линейный выход сигнала на внешний усили-

тель или магнитофон, уровень сигнала порядка 0,1-0,3 В. *Speaker Out* — выход на акустические системы или головные телефоны. Подключать к нему внешний усилитель

- мощности нецелесообразно, поскольку здесь искажения больше, чем на линейном выхоле.

Для подключения внутренних устройств CD-ROM к аналоговым входам используются четырехштырьковые разъемы, различающиеся как шагом между выводами, так и их назначением. Часто ставят рядом несколько разъемов с параллельно соединенными сигнальными контактами. Но это может не сработать, если кабель имеет другое расположение сигналов. Тогда можно переустановить контакты на разъеме кабеля, для чего иголкой нажимают на фиксирующий выступ контакта, после чего контакт вытягивают в сторону кабеля и переставляют в другое гнездо. Сигнальные контакты аудиовходов см. на рис. 3.6. Разъем может иметь ключ с противоположной стороны (по ошибке сборщика кабеля или по внутреннему стандарту его производителя). Задача подключения облегчается тем, что требует правильной расстановки только двух сигнальных контактов. Контакты общего провода выделяются тем, что на плате соединяются с шиной, а на



кабеле — с экраном. Положение левого и правого каналов

Рис. 3.6. Внутренние разъемы подключения аудиосигналов

### 3.5. Интерфейсы видеомониторов

В традиционной технике цветного телевизионного вещания (РАL, SECAM или NTSC) видеосигнал непосредственно несет информацию о мгновенном значении яркости, а цветовая информация передается в модулированном виде на дополнительных частотах. Таким образом обеспечивается совместимость черно-белого приемника, игнорирующего цве-

подходит, поскольку они имеют существенно ограниченную полосу пропускания цветовых каналов. Для графики низкого разрешения, при которой частоты синхронизации были близки к стандартным телевизионным, использовался интерфейс *Composite Video*. По коаксиальному кабелю (75 Ом) передавался полный стандартный видео-

сигнал с размахом около 1,5 В. В видеотехнике этот сигнал называют низкочастотным, имея в виду то, что по нему по-

товую информацию, с цветным передающим каналом. Однако для вывода графической информации с высоким разрешением ни одна из традиционных вещательных систем не

дается прямой, а не модулированный сигнал. Соответствующий ему вход имеется не у каждого телевизора. При наличии дополнительного радиочастотного модулятора *RFM* (Radio Frequency Modulator) можно было подключаться к антенному входу стандартного телевизионного приемника, но при этом еще более снижалось реальное разрешение графики. Для композитного интерфейса используют коаксиаль-

Для мониторов при высоком разрешении можно использовать только прямую подачу сигнала на входы видеоусилителей базовых цветов — RGB- $exo\partial$  ( $Red\ Green\ Blue\ —$  красный, зеленый и синий). Интерфейс между видеоадаптером и монитором может быть как дискретным (с сигналами ТТЛ),

ные разъемы RCA («колокольчик»), широко применяемые

# так и аналоговым. 3.5.1. Дискретный интерфейс RGB TTL

в видео- и аудиотехнике.

Первые мониторы для PC имели цифровой интерфейс с уровнями ТТЛ (табл. 3.5) —  $RGB\ TTL$ . Для монохромного монитора использовали лишь два сигнала — видео (включить/выключить луч) и повышенной яркости. Таким образом, монитор мог отобразить три градации яркости:

зом, монитор мог отобразить три градации яркости: хотя  $2^2$ =4, но «темный пиксел» и «темный с повышенной яркостью» неразличимы. В цветных мониторах класса CD

(Color Display) имелось по одному сигналу для включения каждого луча и общий сигнал повышенной яркости. Таким образом, можно было задать 16 цветов. Следующий класс — улучшенный цветной дисплей ECD (Enhanced Color Display)

достигло 26=64. Сигналы RED, GREEN, BLUE и Red, Green, Blue обозначают, соответственно, старшие и младшие биты базисных цветов.

Строчная и кадровая синхронизация монитора осуществляется сигналами H.Sync и V.Sync. Монохромные адаптеры

имел цифровой интерфейс с двумя сигналами на каждый базовый цвет. Сигналы позволяли задавать одну из 4 градаций интенсивности; общее количество колируемых цветов

ется сигналами H.Sync и V.Sync. Монохромные адаптеры MDA и HGC, работающие с высоким разрешением (720×350 пикселов), используют высокую частоту развертки. Адаптер CGA работает с низкими частотами (параметры синхронизации близки к телевизионным). Адаптеры и мониторы EGA могут работать с любыми из этих частот. Для облегчения переключения режимов генератора развертки монитора используют сигнал V.Sync: полярность импульсов определяет диапазон частот развертки текущего видеорежима. Для всех разновидностей интерфейса RGB TTL используется разъем

Табляца 3.5. Цяфровой интерфейс монитора (RGB TTL)

Контакт Монитор

МDA/HGC (GA FGA Color/Mono

DB-9S.

| контакт | монитор   |           |                |
|---------|-----------|-----------|----------------|
|         | MDA/HGC   | CGA       | EGA Color/Mono |
| 1       | GND       | GND       | GND            |
| 2       | GND       | GND       | Red            |
| 3       | _         | RED       | RED            |
| 4       | -         | GREEN     | GREEN          |
| 5       | _         | BLUE      | BLUE           |
| 6       | Intensiv. | Intensiv. | Green/Intens.  |
| 7       | Video     | Reserved  | Blue/Video     |
| 8       | +H.Sync.  | +H.Sync.  | +H,Sync.       |
| 9       | -V.Sync.  | +V.Sync.  | -(+)V.Sync.    |

# 3.5.2. Аналоговый интерфейс RGB

Из-за ограничений цифрового интерфейса пришлось перейти на аналоговый интерфейс, перенеся цифроаналоговые

ЦАП для каждого цвета в настоящее время позволяет выводить 16,7 миллиона цветов (*True Color*). Этот интерфейс называется *RGB Analog*, в нем базовые цвета передаются аналоговыми сигналами с отдельными обратными линиями по витым парам. Черному цвету соответствует нулевой

потенциал на линиях всех цветов, полной яркости каждого цвета соответствует уровень +0,7 В. Сигналы управления, состояния и синхронизации передаются сигналами ТТЛ. Впервые аналоговый интерфейс был применен на адаптере

преобразователи сигналов базовых цветов из монитора на графический адаптер. Такой интерфейс с 8-разрядными

PGA фирмы IBM, где для него использовался 9-контактный разъем DB-9S (табл. 3.6). В дальнейшем, начиная с адаптеров VGA, стали применять малогабаритный 15-контактный разъем с таким же внешним размером (табл. 3.7). По назначению сигналов эти интерфейсы в основном совпадают, и существуют даже переходные кабели с 15- на 9-контактные разъемы (табл. 3.8). В адаптере PGA используется совмещенная синхронизация (Composite Sync) сигна-

Таблица 3.6. Аналоговый интерфейс монитора PGA (разъем DB-9S)

лом (H+V)Sync., этот режим поддерживают и многие совре-

| Контакт | Сигнал       |
|---------|--------------|
| 1       | Red          |
| 2       | Green        |
| 3       | Blue         |
| 4       | (H+V)Sync    |
| 5       | Mode Control |
| 6       | Red Return   |
| 7       | Green Return |
| 8       | Blue Return  |
| 9       | GND          |

менные мониторы.

Таблица 3.7. Аналоговый интерфейс монитора (RGB Analog)

Монитор

Видеоадаптер

Контакт

| DB-15             | MCGA/VGA/SVGA/XGA                                                             | Mono                   | Color                  |
|-------------------|-------------------------------------------------------------------------------|------------------------|------------------------|
| 1                 | Red                                                                           | -                      | Red                    |
| 2                 | Green                                                                         | Video                  | Green                  |
| 3                 | Blue                                                                          | -                      | Blue                   |
| 4                 | ID2                                                                           | -                      | -                      |
| 5                 | GND/DDC Return <sup>1</sup>                                                   | SelfTest/DDC<br>Return | SelfTest/DDC<br>Return |
| 6                 | Red Return                                                                    | Key                    | Red Return             |
| 7                 | Green Return                                                                  | Video Return           | Green Return           |
| 8                 | Blue Return                                                                   | -                      | Blue Return            |
| 9                 | Ключ (нет контакта)                                                           | -                      |                        |
| 10                | GND                                                                           | GND                    | GND                    |
| 11                | ID0                                                                           | -                      | GND                    |
| 12                | ID1/SDA <sup>1</sup>                                                          | -/SDA                  | GND/SDA                |
| 13                | H.Sync/(H+V)Sync <sup>2</sup>                                                 | H.Sync/(H+V)Sync       | H.Sync/(H+V)Sync       |
| 14                | V.Sync                                                                        | V.Sync                 | V.Sync                 |
| 15                | SCL <sup>1</sup>                                                              | SCL.                   | SCL.                   |
| DDC. П<br>монитор | ы DDC Return, SDA и S<br>(ри этом контакт 9 мож<br>ра.<br>(H+V)Svnc используе | ет использоваться      | для питания логикі     |

Сигнал (H+V)Sync используется при совмещенной синхронизации (Composite Sync).

### Таблица 3.8. Переходник 9-15 вналогового интерфейса монитора

| Контакт DB9 | Сигнал       | Контакт DB15 |
|-------------|--------------|--------------|
| 1           | Red          | 1            |
| 2           | Green        | 2            |
| 3           | Blue         | 3            |
| 4           | H.Sync       | 13           |
| 5           | V.Sync       | 14           |
| 6           | Red Return   | 6            |
| 7           | Green Return | 7            |
| 8           | Blue Return  | 8            |
| 9           | GND          | 10, 11       |

(штырьки этих разъемов тоньше и слабее, чем у 9-контактных). Естественно, монитор, подключенный таким образом, работать не будет.

В компьютерах Macintosh монитор, совместимый по параметрам с VGA, имеет разъем DB-15P (такой же, как и у Game-порта PC). Назначение его выводов приведено в табл. 3.9.

Несмотря (в прямом смысле) на наличие ключа — D-образного кожуха — 15-контактные разъемы ухитряются вставлять в перевернутом положении, при этом один из контактов среднего ряда подгибается, а потом и ломается

### Таблица 3.9. Развем VGA Macintosh

| Контакт | Сигнал          |
|---------|-----------------|
| 1       | Red Return      |
| 2       | Red             |
| 3       | Comp.Sync       |
| 4       | ID0             |
| 5       | Green           |
| 6       | Green Return    |
| 7       | ID1             |
| 8       | Не используется |
| 9       | Blue            |
| 10      | ID2             |
| 11      | Sync. GND       |
| 12      | V.Sync          |
| 13      | Blue Return     |
| 14      | H.Sync GND      |
| 15      | H.Sync          |

Кроме передачи изображения по интерфейсу передают информацию, необходимую для автоматизации согласования параметров и режимов монитора и компьютера. «Интересы» компьютера представляет дисплейный адаптер, к кото-

рому и подключается монитор. С его помощью обеспечиваются идентификация монитора, необходимая для PnP, и управление энергопотреблением монитора.

Для простейшей *идентификации* в интерфейс ввели три логических сигнала IDO—ID2, по которым адаптер мог определить тип подключенного монитора IBM (табл. 3.10). Со стороны монитора эти линии либо подключались к шине GND, либо оставлялись неподключенными. Однако из этой системы идентификации использовали лишь сигнал ID1, по которому определяют подключение монохромного монитора. Монохромный монитор может быть опознан адаптером и иначе — по отсутствию нагрузки на линиях Red и Blue.

Таблица 3.10. Параллельная идентификация мониторов IBM

| Дисплей                 | IDO | ID1 | ID2 |
|-------------------------|-----|-----|-----|
| Монохромный 12" IBM8503 | NC  | GND | NC  |
| Цветной 12" IBM8513     | GND | NC  | NC  |
| Цветной 14" IBM8512     | GND | NC  | NC  |
| Цветной 15" IBM8514     | GND | NC  | GNE |

Параллельную идентификацию мониторов заменила после-

довательная по каналу цифрового интерфейса VESA DDC (Display Data Channel). Этот канал построен на интерфейсе I<sup>2</sup>C (DDC2B) или ACCESS Bus (DDC2AB), которые используют всего два ТТЛ-сигнала SCL и SDA. Интерфейс DDC1 является однонаправленным — монитор посылает адаптеру блок своих параметров по линии SDA (контакт 12), которые синхронизируются сигналом V.Sync (контакт 14). На время приема блока параметров адаптер может повысить частоту V.Sync до 25 кГц (генератор кадровой развертки по такой высокой частоте синхронизироваться не будет). Интерфейс DDC2 является двунаправленным; для синхронизации используется выделенный сигнал SCL (контакт 15). Интерфейс DDC2AB отличается тем, что допускает подключение ПУ, не требующих высокой скорости обмена, к компьютеру по последовательной шине ACCESS Bus. При этом внешний разъем шины выносится на монитор (см. табл. 7.3).

Блок параметров расширенной идентификации дисплея *EDID* (Extended Display Identification) имеет одну и ту же структуру для любой реализации DDC (табл. 3.11).

### Таблица: 3.11. Блож расширенной идентификации EDID

| Смещение,<br>байт | Длина,<br>байт | Назиачение                                           |  |
|-------------------|----------------|------------------------------------------------------|--|
| 0                 | 8              | Заголовок (индикатор начала потока<br>EDID)          |  |
| 8                 | 10             | Идентификатор изделия (назначается производителем)   |  |
| 18                | 2              | Версия EDID                                          |  |
| 20                | 15             | Основные параметры и возможности дисплея             |  |
| 35                | 19             | Установленные параметры<br>синхронизации             |  |
| 54                | 72             | Дескрипторы параметров<br>синхронизации (байты 4-18) |  |
| 126               | 1              | Флаг расширения                                      |  |
| 127               | 1              | Контрольная сумма                                    |  |

Для управления энергопотреблением монитора в соответствии со стандартом VESA *DPMS* (Display Power Management Signaling) используются сигналы кадровой и строчной синхронизации V.Sync и H.Sync (табл. 3.12).

### Таблица: 3.12, Управление энергопотраблением монитора (VESA DPMS)

| Режим   | H.Sync    | V.Sync    |  |
|---------|-----------|-----------|--|
| On      | Активен   | Активен   |  |
| Standby | Неактивен | Активен   |  |
| Suspend | Активен   | Неактивен |  |
| Off     | Неактивен | Неактивен |  |

Разъемы, применяемые в современных адаптерах и мониторах SVGA, не предназначены для передачи высокочастотных сигналов. Пределом для них является примерно 150 МГц, что

для высокого разрешения и высокой частоты регенерации недостаточно. Поэтому на больших профессиональных мониторах с высокими разрешением и частотами синхронизации и на соответствующих адаптерах имеются *BNC-разъемы* для соединения с помощью коаксиальных кабелей.

### 3.5.3. Комбинированный интерфейс EVC

Для расширения частотного диапазона и, учитывая тенденцию к использованию последовательных шин USB и FireWire, для подключения ПУ к системному блоку компьютера VESA предложила новый тип разъема EVC (Enhanced Video Connector). Кроме обычного аналогового интерфейса RGB и канала DDC2 разъем EVC имеет контакты для видеовхода, входные и выходные стереоаудиосигналы, шины USB и FireWire, а также линии питания постоянного тока для зарядки аккумуляторов портативных ПК. Разъем имеет две секции: высокочастотную для присоединения четырех коаксиальных кабелей и низкочастотную на 30 контактов (рис. 3.7). Контакты высокочастотной секции, хотя и не являются коаксиальными, позволяют передавать сигналы с частотами до 2 ГГц. Контактом экранов является крестообразная перегородка. При использовании 75-омных коаксиальных кабелей на частоте 500 МГц гарантируется уровень отражений и перекрестных помех не выше 2%. Контакты С1, С2 и С4 используются для передачи цветовых сигналов R, G и В соответственно, контакт С3 служит для передачи синхросигнала пикселов. Низкочастотная секция описана в табл. 3.13. Разъем поделен на компактные зоны для каждой группы сигналов, правда, шины USB и 1394 используют общий контакт для экрана. Назначение контактов видеовхода (S-Video или композитный, PAL или NTSC) может программироваться по каналу DDC2.



Рис. 3.7. Разъем EVC (розетка)

Стандарт определяет три уровня реализации: базовый, мультимедийный и полный. Базовый включает только видеосигналы и DDC, в мультимедийном должны быть аудиосигналы. При использовании коннектора в полном объеме монитор превращается в коммутационный центр, который соединяется с компьютером одним кабелем, а все остальные ПУ

| (включая клавиатуру, мышь, принтер) подключаются к монитору. Разъем может использоваться для подключения портативного ПК к док-станции. EVC собирает сигналы от разных подсистем — графической, видео, аудио, последовательных шин и питания. Этот общий разъем, устанавливаемый на корпусе системного блока, может соединяться с разными платами внутренними кабелями через промежуточные разъемы.  Таблица 3.13. Назвичения контактов вызвочастолюй частв EVC |                          |         |                                      |         |                         |  |  |
|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------|---------|--------------------------------------|---------|-------------------------|--|--|
| Контакт                                                                                                                                                                                                                                                                                                                                                                                                                                                         | Цепь                     | Контакт | Цепь                                 | Контакт | Цепь                    |  |  |
| 1                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Audio Output,<br>Right   | 11      | Charging<br>power input, +           | 21      | Audio input,<br>left    |  |  |
| 2                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Audio Output,<br>Left    | 12      | Charging<br>power input, –           | 22      | Audio input,<br>right   |  |  |
| 3                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Audio Output,<br>Return  | 13      | Video input,<br>Y or<br>composite in | 23      | Audio input,<br>return  |  |  |
| 4                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Sync Return              | 14      | Video input,<br>return               | 24      | Stereo sync<br>(TTL)    |  |  |
| 5                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Horizontal<br>Sync (TTL) | 15      | Video input,<br>C in                 | 25      | DDC return              |  |  |
| 6                                                                                                                                                                                                                                                                                                                                                                                                                                                               | Vertical Sync<br>(TTL)   | 16      | USB data +                           | 26      | DDC data<br>(SDA)       |  |  |
| 7                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RESERVED 1               | 17      | USB data –                           | 27      | DDC, clock<br>(SCL)     |  |  |
| 8                                                                                                                                                                                                                                                                                                                                                                                                                                                               | RESERVED 2               | 18      | USB/1394<br>common<br>mode shield    | 28      | +5 B                    |  |  |
| 9                                                                                                                                                                                                                                                                                                                                                                                                                                                               | 1394 pair A,<br>data –   | 19      | 1394 Vg                              | 29      | 1394 pair B,<br>clock + |  |  |
| 10                                                                                                                                                                                                                                                                                                                                                                                                                                                              | 1394 pair B,<br>data +   | 20      | 1394 Vp                              | 30      | 1394 pair B,<br>clock – |  |  |

# 4. Шины расширения

Шины расширения (Expansion Bus) предназначены для подключения различных адаптеров ПУ. Интерфейсы шин расширения РС ведут историю с 8-битной шины ISA. Ее открытость обеспечила появление широкого спектра плат расширений, позволивших использовать РС в различных сферах. С появлением АТ-286 шина была расширена по разрядности и возможностям. Шина EISA была призвана сделать обмен еще более производительным и надежным. Она содержала прогрессивные идеи автоматизации конфигурирования (прототип PnP), позволяя устанавливать и ISA-адаптеры. Шина МСА, предложенная ІВМ, не была поддержана производителями РС, так как ее спецификация была закрытой. С появлением процессора 486 родилась высокоскоростная локальная шина VLB. Однако она являлась дополнением к слоту шины ISA/EISA и использовалась в основном лишь для графических карт и дисковых контроллеров. Принципиальная привязка к шине процессора 486 не обеспечила ей долголетия. Современная скоростная шина PCI является стандартной для компьютеров с процессорами х86 всех поколений старше четвертого, она используется в Power PC и других платформах. Развитием шины РСІ, нацеленным на дальнейшее ускорение обмена, явился порт АСР, предназначенный для подключения графических адаптеров. Для блокнотных компьютеров, поначалу имевших закрытую архитектуру, потребность в подключении периферии привела к появлению стандартизованной шины PCMCIA, впоследствии переименованной в PC Card.

Шины расширения системного уровня позволяют адаптерам максимально использовать системные ресурсы РС: пространства памяти и ввода/вывода, прерывания, каналы прямого доступа к памяти. Как следствие, изготовителям модулей расширения приходится точно следовать протоколам шины, выдерживая жесткие частотные и нагрузочные параметры, а

также временные диаграммы. Отклонения приводят к несовместимости с некоторыми системными платами. Если при подключении к внешним интерфейсам это приведет к неработоспособности только самого устройства, то некорректное подключение к системной шине может блокировать работу всего компьютера. Следует также учитывать ограниченность ресурсов РС. Самые дефицитные из них — линии запросов прерываний (каналы прямого доступа можно заменить на активное управление шиной РСІ). Проблемы распределения ресурсов на шинах решаются по-разному, но чаще всего применяется технология PnP.

рения РС. Табляца 4.1, Характебистика шин расширения

В табл. 4.1 даны характеристики стандартных шин расши-

| Шина   | Пропускная<br>способность,<br>Мбайт/с* | Канаяы<br>DMA | Bus-<br>Master | ACFG** | Разрядность<br>данных | Разрядность<br>адреса | Частота,<br>МГц |
|--------|----------------------------------------|---------------|----------------|--------|-----------------------|-----------------------|-----------------|
| ISA-8  | 4                                      | 3             | _              | -      | 8                     | 20 (1 Мбайт)          | 8               |
| ISA-16 | 8/(16)                                 | 8             | +              | -      | 16                    | 24 (16 Мбайт)         | 8/(16)          |
| EISA   | 33,3                                   | 8             | +              | +      | 32                    | 32 (4 Гбайт)          | 8,33            |
| MCA-16 | 16                                     |               | +              | +      | 16                    | 24 (16 Мбайт)         | 10              |
| MCA-32 | 20                                     | _             | +              | +      | 32                    | 32 (4 Гбайт)          | 10              |
| VLB    | 132                                    | -             | (+)            | -      | 32/64                 | 32 (4 Гбайт)          | 33-50(66)       |
| PCI    | 132/264                                | -             | -              | +      | 32/64                 | 32 (4 Гбайт)          | 33(66)          |
| PCMCIA | -                                      | -             | -              | +      | 16                    | 26 (64 Мбайт)         | 33              |

- Указана максимальная пропускная способность. Реальная примерно в 2 раза ниже за счет прерываний, регенерации и протокольных процедур.
- \*\* Поддержка автоматнческого конфигурирования. Для ISA PnP является позднейшей надстройкой, реализуемой адаптерами и ПО.

Шины расширения конструктивно оформляются в виде щелевых разъемов (слотов) на системной плате для установки плат адаптеров. Унификация системных плат, корпусов и плат расширения обеспечивается:

- стандартизацией размеров, количества контактов и электрического интерфейса слотов шин расширения;
- фиксированным расстоянием от слота до задней кромки платы;

ты) карт расширения;

« определением геометрии нижнего края платы расшире-

фиксированным шагом между соседними слотами, а также

их привязкой к крепежным точкам и разъему клавиатуры; определением максимальных габаритов (длины и высо-

\*

ния, формы и размера фиксирующей скобки.

Размеры карт расширения для самой популярной шины — ISA — приведены на рис. 4.1.



Рис. 4.1. Карта расширения для шины ISA



Рис. 4.2. Вид и положение слотов шин расширения

Типы слотов легко определить визуально (рис. 4.2). На этом рисунке присутствие всех типов шин условно — реально на

«Media BUS», дополняющий слот PCI сигналами шины ISA. У адаптеров для шины PCI, в отличие от ISA/EISA и VLB, компоненты расположены на левой стороне печатной платы. Для экономии места на системной плате используют так называемый разделяемый слот (Shared Slot). На самом деле это разделяемое окно на задней стенке корпуса, которое может использоваться либо картой ISA, либо картой PCI. Таким образом, максимальное суммарное количество доступных слотов оказывается на единицу меньшим, чем видимое количество. Для низкопрофильных корпусов системные платы имеют всего один слот расширения, в который устанавливается специальная плата-переходник Riser Card. Этот переходник специфичен для модели системной платы (корпуса), поскольку на его краевой разъем заводятся линии нескольких системных шин. Если Riser Card имеет слоты только шины ISA, он обычно вставляется в стандартный слот ISA-16. С точки зрения уменьшения наводок и паразитных емкостей лучше использовать специальные платы с одним разъемом, чтобы не перегружать шину неиспользуемыми проводниками и разъемами. Шины расширения допускают конфигурирование, которое предполагает в основном настройку их временных параметров: Для шины VLB применяется перемычка, управляющая делителем частоты сигнала синхронизации в зависимости от

системных платах находится не более двух-трех типов слотов. Распространенные сочетания: ISA+PCI, ISA+VLB, EISA+PCI, EISA+VLB. Фирмой ASUSTek применяется слот

того, превышает ли системная частота 33,3 МГц. Для шины PCI частота синхронизации определяется частотой системной шины процессора. Кроме того, режимы могут определяться в BIOS Setup.

Для шины ISA кроме частоты (которая должна быть порядка 8 МГц) задают время восстановления для 8- и

16-битных обращений к памяти и вводу/выводу. Неустойчивая работа адаптеров может потребовать замедления шины ISA. Понижение ее производительности не отражается на общей производительности современных компьютеров.

Иногда для шин ISA и PCI опциями BIOS Setup приходится распределять системные ресурсы (линии запросов прерываний)(см. приложение A).

ISA Bus (Industry Standard Architecture) — шина расшире-

# 4.1. Шины ISA, EISA и PC-104

ния, применявшаяся с первых моделей РС и ставшая промышленным стандартом. В компьютере XT использовалась шина с разрядностью данных 8 бит и адреса — 20 бит. В компьютерах АТ ее расширили до 16 бит данных и 24 бит адреса. В таком виде она существует и поныне. Конструктивно шина выполнена в виде двух щелевых разъемов с щагом выводов 2,54 мм (0,1 дюйма) (см. рис. 4.3). Подмножество ISA-8 использует только 62-контактный слот (ряды А. В), в ISA-16 применяется дополнительный 36-контактный слот (ряды C, D). Шина обеспечивает возможность отображения 8- или 16-битных регистров на пространство ввода/вывода и памяти. Диапазон адресов памяти ограничен областью UMA (выше A0000h). Для шины ISA-16 опциями BIOS Setup может быть разрешено пространство между 15-м и 16-м мегабайтами памяти (при этом компьютер не сможет использовать более 15 Мбайт ОЗУ). Диапазон адресов ввода/вывода сверху ограничен количеством используемых для дешифрации бит адреса, нижняя граница ограничена областью адресов 0—FFh, зарезервированных под устройства системной платы. В РС была принята 10-битная адресация ввода/вывода, при которой ли-

са, нижняя граница ограничена областью адресов о—FFI, зарезервированных под устройства системной платы. В РС была принята 10-битная адресация ввода/вывода, при которой линии адреса A[15:10] устройствами игнорировались. Таким образом, диапазон адресов устройств шины ISA ограничивается областью 100h—3FFh, то есть всего 758 адресов 8-битных регистров. На некоторые из адресов претендуют системные устройства (см. табл. А.1). Впоследствии стали применять 12-битную адресацию (диапазон 100h—FFFh). При ее использовании необходимо учитывать возможность присутствия на шине старых 10-битных адаптеров, которые «отзовутся» на адрес с подходящими ему битами A[9:0] во всей допустимой области 12-битного адреса четыре раза (у каждого 10-битного адреса будет еще по три 12-битных псевдонима).



Рис. 4.3. Слот ISA

Шина ISA-8 может предоставить до 6 линий запросов прерываний, ISA-16 — 11. Часть их могут «отобрать» устройства системной платы или шина PCI.

Шина позволяет использовать до трех 8-битных каналов DMA. На 16-битной шине доступны еще три 16-битных канала. Сигналы 16-битных каналов могут использоваться для прямого управления шиной устройством Bus-Master. При этом канал DMA применяется для арбитража шины, а адаптер Bus-Master формирует все адресные и управляющие сигналы шины, не забывая передать управление шиной процессору не позднее, чем через 15 мкс (чтобы не нарушить регенерацию памяти).

Все перечисленные ресурсы системной шины должны быть бесконфликтно распределены. Бесконфликтность подразумевает следующее:

- Каждое устройство должно управлять шиной данных только при чтении по своим адресам или по используемому им каналу DMA. Области адресов для чтения не должны пересекаться. «Подсматривать» операции записи, «адресованные не ему», не возбраняется.

Задача распределения ресурсов для старых адаптеров решалась с помощью джамперов, затем появились программно конфигурируемые устройства, которые вытесняются автоматически конфигурируемыми платами PnP.

С появлением 32-битных процессоров делались попытки расширения разрядности шины, но все 32-битные шины ISA не являются стандартизованными, кроме EISA.

EISA Bus (Extended ISA) — стандартизованное расширение

ISA до 32 бит. Конструктивное исполнение обеспечивает совместимость с ней ISA-адаптеров (рис. 4.4). Узкие дополнительные контакты расширения (ряды Е, F, G, H) расположены между ламелями (контактными площадками) разъема ISA и ниже ламелей А, В, С, D таким образом, что адаптер ISA, не имеющий дополнительных ключевых прорезей в краевом разъеме, не достает до них. Установка карт EISA в слоты ISA недопустима, поскольку ее цепи попадут на контакты ISA, в результате чего системная плата окажется неработоспособной (к счастью, «без дыма»).



**Рис. 4.4.** Разъем шины EISA Для режимов EISA используются дополнительные управля-

ющие сигналы, обеспечивающие более эффективные режимы передачи. В обычном (не пакетном) режиме передачи за каждую пару тактов может быть передано до 32 бит (один

такт на фазу адреса, один — на фазу данных). В пакетном режиме (Burst Mode) пакеты данных пересылаются без указания текущего адреса внутри пакета. В пакете очередные данные передаются в каждом такте шины, длина пакета достигает 1024 байт. Шина предусматривает более производительные режимы DMA (см. прил. А.4), при которых скорость обмена может достигать 33 Мбайт/с. Линии запросов прерываний допускают разделяемое использование, причем сохраняется совместимость с ISA-картами: каждая линия запроса может программироваться на чувствительность как по высокому (как в ISA), так и по низкому уровню. Шина до-

не потребляет ни один из адаптеров. Многие решения EISA напоминают МСА. Каждый слот (мак-(2000) симум -8) и системная плата имеют селективное разрешение адресации ввода/вывода и отдельные линии запроса и подтверждения управления шиной. Арбитраж запросов выполняет устройство ISP (Integrated System Peripheral). При-

оритеты (в порядке убывания): регенерация, DMA, CPU, Bus-Master. Обязательной принадлежностью системной платы с шиной EISA является энергонезависимая память конфигурации NVRAM, в которой хранится информация об устройствах EISA для каждого слота. Формат записей стандартизован, для модификации информации применяется специальная утилита ECU (EISA Configuration Utility). Apхитектура позволяет при использовании программно конфигурируемых адаптеров автоматически разрешать конфликты, но в отличие от PnP не допускает динамического конфигурирования — после выхода из режима конфигури-

пускает потребление каждой картой расширения мощности до 45 Вт, но это не означает, что мощность блока питания для 8 слотов должна быть более 360 Вт — полную мощность

рования необходима перезагрузка. Изолированный доступ к портам ввода/вывода каждой карты во время конфигурирования обеспечивается просто: сигнал AEN, разрешающий декодирование адреса в цикле ввода/вывода, на каждый слот приходит по отдельной линии АЕNх, в это время программно-управляемой. Так можно обращаться и к картам ISA, но из этого нельзя извлечь выгоды, поскольку они не поддер-

живают обмена конфигурационной информацией. Идеи конфигурирования EISA были использованы в спецификации PnP для шины ISA (формат конфигурационных записей

ESCD напоминает NVRAM EISA).

табл. 4.2 и 4.3.

EISA — дорогая, но оправдывающая себя архитектура, применяющаяся в многозадачных системах и на серверах, где требуется высокоэффективное расширение шины ввода/вы-

вода. Перед шиной РСІ у нее есть преимущество в количестве слотов (8 против 4). Назначение контактов слотов шин ISA и EISA приведено в

#### Таблица: 4.2. Разъемы цин ISA-8, ISA-16 и EISA

N#

Ряд А

Ряд Е

Ряд В

Ряд F

| 174                                                                                                                 | 1 744 5              | 1417 | 1 744 15 | 1 7/4 -              |  |
|---------------------------------------------------------------------------------------------------------------------|----------------------|------|----------|----------------------|--|
| GND                                                                                                                 | GND                  | 1    | IOCHK    | CMD#                 |  |
| +5 B                                                                                                                | Reset                | 2    | Data 7   | START#               |  |
| +5 B                                                                                                                | +5 B                 | 3    | Data 6   | EXRDY                |  |
| Unused                                                                                                              | IRQ 2/9 <sup>1</sup> | 4    | Data 5   | EX32#                |  |
| Unused                                                                                                              | -5 B                 | 5    | Data 4   | GND                  |  |
| Key                                                                                                                 | DRQ 2                | 6    | Data 3   | Key                  |  |
| Unused                                                                                                              | -12 B                | 7    | Data 2   | EX16#                |  |
| Unused                                                                                                              | 0WS# <sup>2</sup>    | 8    | Data 1   | SLBURST#             |  |
| +12 B                                                                                                               | +12 B                | 9    | Data 0   | MSBURST#             |  |
| M/-IO                                                                                                               | GND                  | 10   | IOCHDRY  | W/R#                 |  |
| -LOCK                                                                                                               | SmemWR#              | 11   | AENx     | GND                  |  |
| Reserved                                                                                                            | SmemRD#              | 12   | Addr 19  | EMB66# <sup>3</sup>  |  |
| GND                                                                                                                 | IO WR#               | 13   | Addr 18  | EMB133# <sup>3</sup> |  |
| Reserved                                                                                                            | IO RD#               | 14   | Addr 17  | Reserved             |  |
| BE 3#                                                                                                               | DACK 3#              | 15   | Addr 16  | GND                  |  |
| Key                                                                                                                 | DRQ 3                | 16   | Addr 15  | Key                  |  |
| BE 2#                                                                                                               | DACK 1#              | 17   | Addr 14  | BE 1#                |  |
| BE 0#                                                                                                               | DRQ 1                | 18   | Addr 13  | LA 31#               |  |
| GND                                                                                                                 | Refr#                | 19   | Addr 12  | GND                  |  |
| +5 B                                                                                                                | Bclock               | 20   | Addr 11  | LA 30#               |  |
| LA 29#                                                                                                              | IRQ 7                | 21   | Addr 10  | LA 28#               |  |
| GND                                                                                                                 | IRQ 6                | 22   | Addr 9   | LA 27#               |  |
| LA 26#                                                                                                              | IRQ 5                | 23   | Addr 8   | LA 25#               |  |
| LA 24#                                                                                                              | IRQ 4                | 24   | Addr 7   | GND                  |  |
| Key                                                                                                                 | IRQ 3                | 25   | Addr 6   | Key                  |  |
| LA 16                                                                                                               | DACK 2#              | 26   | Addr 5   | LA 15                |  |
| LA 14                                                                                                               | TC                   | 27   | Addr 4   | LA 13                |  |
| +5 B                                                                                                                | BALE                 | 28   | Addr 3   | LA 12                |  |
| +5 B                                                                                                                | +5 B                 | 29   | Addr 2   | LA 11                |  |
| GND                                                                                                                 | Osc.                 | 30   | Addr 1   | GND                  |  |
| LA 10                                                                                                               | GND                  | 31   | Addr 0   | LA 9                 |  |
| <sup>1</sup> B4: XT=IRQ2, AT=IRQ9. <sup>2</sup> B8: XT=Card Selected. <sup>3</sup> E12, E13 — только для Fast EISA. |                      |      |          |                      |  |

<sup>&</sup>lt;sup>3</sup>E12, E13 — только для Fast EISA.

#### Таблица 4.3. Дополнительные разъемы ими ISA-16 и EISA

| Ряд Н   | Ряд D   | N# | Ряд С   | Ряд G   |
|---------|---------|----|---------|---------|
| LA 8    | MCS16#  | 1  | SBHE#   | LA 7    |
| LA 6    | IOCS16# | 2  | LA 23   | GND     |
| LA 5    | IRQ 10  | 3  | LA 22   | LA 4    |
| +5 B    | IRQ 11  | 4  | LA 21   | LA 3    |
| LA 2    | IRQ 12  | 5  | LA 20   | GND     |
| Key     | IRQ 15  | 6  | LA 19   | Key     |
| Data 16 | IRQ 14  | 7  | LA 18   | Data 17 |
| Data 18 | DACK0#  | 8  | LA 17   | Data 19 |
| GND     | DRQ 0   | 9  | MemRD#  | Data 20 |
| Data 21 | DACK5#  | 10 | MemWR#  | Data 22 |
| Data 23 | DRQ 5   | 11 | Data 8  | GND     |
| Data 24 | DACK6#  | 12 | Data 9  | Data 25 |
| GND     | DRQ 6   | 13 | Data 10 | Data 26 |
| Data 27 | DACK7#  | 14 | Data 11 | Data 28 |
| Key     | DRQ 7   | 15 | Data 12 | Key     |
| Data 29 | +5 B    | 16 | Data 13 | GND     |
| +5 B    | Master# | 17 | Data 14 | Data 30 |
| +5 B    | GND     | 18 | Data 15 | Data 31 |
| MAKx#   | _       | 19 | _       | MREQx   |

Сигналы шины ISA восходят к шинам Microbus и Multibus, они естественны для периферийных микросхем фирмы Intel для процессоров 8080 и 80х86/88. Набор сигналов ISA-8 предельно прост. Программное обращение к ячейкам памяти и пространства ввода/вывода обеспечивают следующие сигналы:

- В Data[7:0] шина данных.

SMemRD# — чтение памяти

 (в диапазоне адресов 0-FFFFFh).

 К сигналам запросов прерывания и каналам прямого доступа

SMemWR# — запись в память (в диапазоне адресов 0-FFFFh).

к памяти относятся следующие:

■ IRQ2/9, IRQ[3:7] — запросы прерываний. Положительный перепад сигнала вызывает запрос аппаратного прерыва-

ния. Для идентификации источника высокий уровень должен сохраняться до подтверждения прерывания про-

- цессором, что затрудняет разделяемое использование прерываний. Линия IRQ2/9 в шинах XT вызывает аппаратное прерывание с номером 2, а в AT с номером 9.

  В DRQ[1:3] запросы 8-битных каналов DMA (положитель-
- ™ ТС признак завершения счетчика циклов DMA.
   Шина имеет и несколько служебных сигналов синхронизации, сброса и регенерации памяти, установленной на адап-
- терах:

   IOCHRDY готовность устройства, низкий уровень удлиняет текущий цикл (не более 15 мкс).

ВАLЕ — разрешение защелки адреса. После его спада в

- каждом цикле процессора линии Addr 0-19 гарантированно содержат действительный адрес.

  Веfr# цикл регенерации памяти (в XT называется DACK 0#). Сигнал появляется каждые 15 мкс, при этом шина адреса указывает на очередную регенерируемую
- зывает NMI СРО (разрешение и индикация в системных портах 061h, 062h).

  В Reset сигнал аппаратного сброса (активный уровень —

высокий).

ПУ могут не использовать этот сигнал, работая только по управляющим сигналам записи и чтения. OSC — частота 14,431818 МГц, несинхронизированная с шиной (использовалась старыми дисплейными адаптерами).

ВСюск — синхронизация шины с частотой около 8 МГц.

- Кроме логических сигналов шина имеет контакты для разводки питания +5, -5, +12 и -12 В. Дополнительный разъем, расширяющий шину до 16-битной,
- содержит линии данных, адреса, запросов прерываний и каналов прямого доступа: Data[15:8] — шина данных.
- SBHE признак наличия данных на линиях Data [15:8]. LA[23:17] — нефиксированные сигналы адреса, требующие зашелкивания по спаду сигнала ВАLE. Такой способ по-
- дачи адреса позволяет сократить время цикла (схемы дешифратора адреса памяти плат расширения начинают декодирование несколько раньше спада BALE).
- IRQ[10:12], IRQ[14:15] дополнительные запросы прерываний. DRQ[5:7] — запросы 16-битных каналов DMA (положи-
- тельным перепадом). DACK[5:7]# — подтверждение запросов 16-битных каналов
- DMA. С переключением разрядности данных связаны сигналы:
- MCS16# адресуемое устройство поддерживает 16-битные обращения к памяти.
- IOCS16# адресуемое устройство поддерживает 16-бит-
- ные обращения к портам.
- К новым управляющим сигналам относятся следующие:
- MemWR# запись в память в любой области до 16 Мбайт.
- MemRD# чтение памяти в любой области до 16 Мбайт. OWS# — сигнал от устройства, разрешающий системной пла-

те укоротить текущий цикл (устранить такты ожидания).

■ MASTER# — запрос от устройства, использующего 16-битный канал DMA на управление шиной. При получении подтверждения DACK [5:7] Bus-Master может захватить шину (не более чем на 15 мкс).

Обобщенные временные диаграммы циклов чтения или записи памяти или ввода/вывода приведены на рис. 4.5. Здесь

условный сигнал CMD\* изображает один из сигналов:

« SMEMRD#, MEMRD# — в цикле чтения памяти;

« SMEMWR#, MEMWR# — в цикле записи памяти;

№ IORD# — в цикле чтения порта ввода/вывода;
 № IOWR# — в цикле записи порта ввода/вывода.



Рис. 4.5. Временные диаграммы циклов чтения или записи на шине ISA
В каждом из рассматриваемых циклов активными (с низ-

ким уровнем) могут быть только сигналы лишь из одной строки данного списка. Цикл прямого доступа к памяти, в котором это правило не соблюдается, рассмотрен в приложении A (см. рис. A.2).

По адресованному ему спаду сигнала *чтения* устройство должно выдать на шину данных содержимое адресуемой ячейки и удерживать его, пока не произойдет подъем сигнала. Во

время циклов записи процессор выставляет действительные данные несколько позже начала (спада) сигнала записи. Уст-

тактов ожидания. При этом циклы обращения к памяти короче циклов обращения к портам ввода/вывода. В шине АТ для управления минимальной длительностью цикла используются также сигналы управления разрядностью передачи: если устройство поддерживает 16-битные передачи, предполагается, что оно может работать с меньшим количеством тактов ожидания. Этим объясняется, что в Setup длительности циклов ISA задаются раздельно как для памяти и вво-

Если устройство не работает с заданными циклами, оно может вводить дополнительные такты ожидания, используя сигнал IOCHRDY, но при этом недопустимо удлинять цикл

Шина EISA позволяет устройствам работать как в режиме ISA, так и в новых режимах EISA. Из сигналов ISA используются линии адреса/данных с расширением их до 32 бит, сигналы прерываний и прямого доступа к памяти и синхро-

да/вывода, так и для 8- и 16-битных операций.

более чем на 15 мкс.

ройство должно фиксировать для себя эти данные в конце цикла по подъему сигнала. Обращение к портам ввода/вывода отличается тем, что сигналы LA[32:17] не используются. Минимальная длительность цикла определяется чипсетом и может программироваться опциями BIOS Setup заданием

низации. Для своих циклов обмена EISA использует собственный набор управляющих сигналов с обязательной синхронизацией по сигналу BCLK. Сигналы IORD# и IOWR# при обращении к EISA-портам не используются. Вместо них применяются сигналы обращения M/IO# и W/R#. В EISA-циклах не используется сигнал SBHE; он заменен сигналами раз-

решения байт BE[3:0]. Вместо общего сигнала AEN каждый слот имеет собственный сигнал AENx. К сигналам расшире-

- LA[31:24]# аналогично LA [2:23], но с инверсией.
   BE[3:0]# индикаторы действительности данных в байтах 0-3 при EISA-цикле.
- тах 0−3 при EISA-цикле.

  м/ю# обращение к памяти (1) или портам (0) EISA.

W/R# — запись (1) или чтение (0) EISA.

- SLBURST# адресуемое устройство поддерживает пакетный режим обмена.
- ный режим обмена.

  \* MSBURST# уведомление устройства, подавшего сигнал
- SLBURST, о намерении инициировать пакетный обмен.

  \*\*\* LOCK# обеспечение исключительного права доступа
- EXRDY готовность EISA-устройства; аналогично сигналу IOCHRDCY.
   START# отмечает начало цикла EISA-доступа. Во вре-

активного EISA Bus-Master к памяти или портам.

- мя действия этого сигнала фиксируется адрес и определяется тип обращения.
- СМD# задает временные параметры цикла; действует после сигнала START#.
- MREQx# EISA Bus-Master слота «х» запрашивает управление шиной.

MAKx# — EISA Bus-Master слота «х» получает управле-

ние шиной от арбитра.

всік

LA(31:2)

M/IO#

BE(3:0)#

W/R#

START#

CMD#

EX32#

EX16#

EXRDY

SD(31:0)(W)

SD(31:0)(W)

**Рис. 4.6.** Временные диаграммы одиночных циклов на шине EISA



Рис. 4.7. Временные диаграммы пакетных циклов на шине EISA

Временные диаграммы одиночных и пакетных циклов обмена по шине EISA приведены на рис. 4.6 и 4.7. Обратим внимание на то, что действительные значения сигналов должны фиксироваться по положительному перепаду ВСLК#, а готовность проверяется по отрицательному.

Для шин ISA ряд фирм выпускают карты-прототипы (Prototype Card), представляющие собой печатные платы полного или уменьшенного формата с крепежной скобой. На платах установлены обязательные интерфейсные цепи — буфер данных, дешифратор адреса и некоторые другие. Остальная часть платы свободна, и здесь разработчик может разместить макетный вариант своего устройства. Эти платы удобны для проверки нового изделия, а также для монтажа единичных экземпляров устройства, когда разработка и изготовление печатной платы нерентабельно.

На некоторых системных платах (ASUSTek) имеется небольшой разъем с загадочным названием *Media Bus*, расположенный позади разъема шины PCI одного из слотов. На этот разъем выводятся сигналы шины ISA. Он предназначен для

промышленного назначения по ряду причин удобнее использовать модули, соединяемые пассивной объединяющей платой. Самый простой соответствующий конструктив заключается в использовании стандартной шины и карты ISA. Все компоненты с традиционной системной платы перенесли на карту ISA, получив одноплатный компьютер, называемый микроРС (mPC — microPC). На такой карте содержатся процессор, память, графический адаптер, контроллеры портов и дисковые интерфейсы, иногда дополнительные контроллеры цифрового и аналогового ввода/вывода. Для подклю-

чения к модулям расширения используют пассивную кроссплату с обычными разъемами ISA. Если требуется более высокопроизводительный канал, применяют шину РСІ. При этом на плате системного контроллера присутствуют два

того, чтобы на графическом адаптере с шиной РСІ можно было разместить недорогой чипсет звуковой карты, предназначенный для шины ISA. Этот разъем и такие комбинированные аудиовидеокарты широкого распространения не получили. Обычно в РС разъемы шины расширения устанавливают на системную плату. Для компьютеров инструментального и

краевых разъема — ISA на обычном месте и PCI примерно на том месте, где располагался разъем VLB. Кросс-плата для таких систем становится неоднородной — часть ее слотов имеет разъемы PCI, другая часть — ISA, место для системного контроллера оборудовано обоими разъемами. Логически эквивалентной ISA является шина *PC-104*, предназначенная для построения встраиваемых контроллеров. 104 — число контактов коннектора, на который выводятся сигналы

шины ISA. От ISA шина PC-104 отличается только типом коннектора и нагрузочными характеристиками линий. Основой контроллера является mPC с разъемом PC-104 (розетка). Если требуется подключение платы расширения, она своей вилкой PC-104 вставляется в плату контроллера. Кроме вил-

ки на плате расширения имеется розетка РС-104 (коннектор двухсторонний), так что можно собрать «бутерброд» из нескольких плат. Если плат более трех, то сверху «бутерброда» устанавливают терминатор. Для фиксации плат стандартизовано расположение крепежных отверстий. Платы скрепляют-

ся несущими стойками (длинными винтами со втулками).

#### 4.2. Шина МСА

MCA (MicroChannel Architecture) — микроканальная архитектура — была введена фирмой IBM для своих компьютеров PS/2, начиная с модели 50. Шина MCA абсолютно несовместима с ISA/EISA. Состав управляющих сигналов, протокол и архитектура ориентированы на асинхронное функционирование шины и процессора, что снимает проблемы согласования скоростей процессора и ПУ. Архитектура позволяет эффективно и автоматически конфигурировать все устройства программным путем (в картах МСА нет ни одного переключателя).

Слоты МСА имеют контакты с шагом 0,05 дюйма. Число слотов на системной плате зависит от модели компьютера.



**Рис. 4.8.** Слоты МСА: a - 16-битный, b - 32-битный, a - 16-битный с расширением

секцию с контактами А48/В48-А89/В89. Перед контактами А1/В1 возможно одно из двух расширений за счет удлинения первой секции (рис. 4.8в): АМ1/ВМ1-АМ4/ВМ4 — для плат расширения памяти;

AV1/BV1-AV10/BV10 - для плат видеоадаптеров. Позволяет использовать общие цепи встроенного в системную плату VGA-адаптера, теоретически удешевляя расширение видеосистемы. По составу сигналов видеорасширение близко к разъему VGA Auxiliary Video Connector или

32-битный слот (рис. 4.8б) имеет удлиненную вторую

№ 16-битный слот (рис. 4.8a) использует контакты A1/B1-А45/В45 для 8-битных операций и А48/В48-А58/В58 для 16-битных. Пропущенные номера 46, 47 — ключ для

всех слотов.

VESA Feature Connector.

популярностью, в частности, из-за полной несовместимости с ISA. МСА находит применение в мощных файл-серверах, где требуется высоконадежный производительный ввод/ вывод. 4.3. Локальная шина VLB Шины ввода/вывода ISA, MCA, EISA имеют низкую

При всей прогрессивности архитектуры МСА не пользуется

производительность, обусловленную их ролью в структуре РС. Современные приложения требуют существенного повышения пропускной способности шины. Одним из решений проблемы стало применение локальной шины процессора 486. Шину процессора использовали как место подключения периферии (контроллера дисков и графичес-

кого адаптера).

VLB (VESA Local Bus) — стандартизованная 32-битная локальная шина, практически представляющая собой сигналы системной шины процессора 486, выведенные на дополни-

тельные разъемы системной платы. Шина ориентирована на процессор 486, хотя возможно ее использование с 386. Для

16, EISA или MCA, располагаясь позади него вблизи от процессора. Из-за ограниченной нагрузочной способности шины процессора больше трех слотов VLB на системной плате не устанавливают. Максимальная тактовая частота шины — 66 МГц, хотя шина работает надежнее на частоте 33 МГц. Декларируется пиковая пропускная способность 132 Мбайт/с (33 МГц×4 байта), но она достигается только

при пакетной передаче. Реально в пакетном цикле передача  $4\times4=16$  байт данных требует 5 тактов шины, так что даже в нем пропускная способность составляет 105,6 Мбайт/с, а в обычном режиме (по такту на фазу адреса и на фазу данных) — 66 Мбайт/с. Жесткие требования к временным характеристикам процессорной шины при большой нагрузке (со стороны микросхем внешнего кэша) могут привести к неустойчивой работе: все три VLB-слота могут использоваться только на частоте 40 МГц. При нагруженной системной плате на 50 МГц может работать только один слот. Шина допускает применение активных (Bus-Master) адап-

процессоров Pentium была принята спецификация 2.0, в которой разрядность шины данных увеличена до 64, но она

Конструктивно VLB-слот аналогичен 16-битному MCA-слоту, но является расширением системного слота шины ISA-

распространения не получила.

теров, но арбитраж запросов возлагается на сами адаптеры. Разрешена установка не более двух Bus-Master-адаптеров, один из которых устанавливается в «Master»-слот. Шину VLB использовали для подключения графического адаптера и контроллера дисков. Встречаются системные платы, которые имеют встроенный графический и дисковый адаптеры с шиной VLB, но самих слотов VLB нет. Это означает, что на плате установлены микросхемы указанных адаптеров для шины VLB. Такая неявная шина по производи-

и совместимости она даже лучше. Назначение контактов шины VLB представлено в табл. 4.4. В названиях сигналов можно узнать сигналы процессора 486.

тельности не уступает обычной, а с точки зрения надежности

Таблица 4.4. Разъем шины VLS

| Ряд В                     |                    | Nº | Ряд А                 |                    |  |
|---------------------------|--------------------|----|-----------------------|--------------------|--|
| 32/64-<br>битный<br>обмен | 64-битный<br>обмен |    | 32/64-битный<br>обмен | 64-битный<br>обмен |  |
| Data 0                    | -                  | 1  | Data 1                | -                  |  |
| Data 2                    | _                  | 2  | Data 3                | _                  |  |
| Data 4                    | -                  | 3  | GND                   | _                  |  |
| Data 6                    | _                  | 4  | Data 5                | _                  |  |
| Data 8                    | _                  | 5  | Data 7                | _                  |  |
| GND                       | -                  | 6  | Data 9                | -                  |  |
| Data 10                   | -                  | 7  | Data 11               | _                  |  |
| Data 12                   | -                  | 8  | Data 13               | -                  |  |
| vcc                       |                    | 9  | Data 15               | -                  |  |
| Data 14                   | -                  | 10 | GND                   | -                  |  |
| Data 16                   | -                  | 11 | Data 17               |                    |  |
| Data 18                   | -                  | 12 | vcc                   | -                  |  |
| Data 20                   | -                  | 13 | Data 19               | -                  |  |
| GND                       | -                  | 14 | Data 21               | -                  |  |
| Data 22                   | -                  | 15 | Data 23               | -                  |  |
| Data 24                   | -                  | 16 | Data 25               | -                  |  |
| Data 26                   | -                  | 17 | GND                   | _                  |  |
| Data 28                   | -                  | 18 | Data 27               | _                  |  |
| Data 30                   | -                  | 19 | Data 29               | -                  |  |
| vcc                       | -                  | 20 | Data 31               | _                  |  |
| Addr 31                   | Data 63            | 21 | Addr 30               | Data 62            |  |
| GND                       | -                  | 22 | Addr 28               | Data 60            |  |
| Addr 29                   | Data 61            | 23 | Addr 26               | Data 58            |  |
| Addr 27                   | Data 59            | 24 | GND                   | -                  |  |
| Addr 25                   | Data 57            | 25 | Addr 24               | Data 56            |  |
| Addr 23                   | Data 55            | 26 | Addr 22               | Data 54            |  |
|                           |                    | -  |                       |                    |  |

vcc

27

Addr 21

Data 53

| Ряд В                     |                    | Nº | Ряд                    | Α                  |
|---------------------------|--------------------|----|------------------------|--------------------|
| 32/64-<br>битный<br>обмен | 64-битный<br>обмен |    | 32/64-битный<br>обмен  | 64-битный<br>обмен |
| Addr 19                   | Data 51            | 28 | Addr 20                | Data 52            |
| GND                       | -                  | 29 | Addr 18                | Data 50            |
| Addr 17                   | Data 49            | 30 | Addr 16                | Data 48            |
| Addr 15                   | Data 47            | 31 | Addr 14                | Data 46            |
| VCC                       | -                  | 32 | Addr 12                | Data 44            |
| Addr 13                   | Data 45            | 33 | Addr 10                | Data 42            |
| Addr 11                   | Data 43            | 34 | Addr 8                 | Data 40            |
| Addr 9                    | Data 41            | 35 | GND                    | -                  |
| Addr 7                    | Data 39            | 36 | Addr 6                 | Data 38            |
| Addr 5                    | Data 37            | 37 | Addr 4                 | Data 36            |
| GND                       |                    | 38 | Write Back             | _                  |
| Addr 3                    | Data 35            | 39 | Byte Enable 0          | Byte<br>Enable 4   |
| Addr 2                    | Data 34            | 40 | vcc                    | -                  |
| Unused                    | LBS64#             | 41 | Byte Enable 1          | Byte<br>Enable 5   |
| Reset                     |                    | 42 | Byte Enable 2          | Byte<br>Enable 6   |
| Data-Code<br>Status       | -                  | 43 | GND                    | _                  |
| Mem-I/O<br>Status         | Data 33            | 44 | Byte Enable 3          | Byte<br>Enable 7   |
| Wr-Rd Status              | Data 32            | 45 | Address Data<br>Strobe | _                  |
| ключ                      | _                  | 46 | ключ                   | _                  |
| ключ                      | _                  | 47 | ключ                   | _                  |
| Ready Return              | _                  | 48 | Local Ready            | -                  |
| GND                       | -                  | 49 | Local Device           | _                  |
| IRQ 9                     | _                  | 50 | Local Request          | -                  |
| Burst Ready               | _                  | 51 | GND                    | _                  |
| Burst Last                | _                  | 52 | Local Bus Grant        | _                  |

| fa6n | HILD I | sa (n | рода | pien | (0) |
|------|--------|-------|------|------|-----|
|      |        |       |      |      |     |

| Ряд В                     |                    | Nº | Ряд А                             |                    |  |
|---------------------------|--------------------|----|-----------------------------------|--------------------|--|
| 32/64-<br>битный<br>обмен | 64-битный<br>обмен |    | 32/64-битный<br>обмен             | 64-битный<br>обмен |  |
| ID 0                      | T -                | 53 | vcc                               | -                  |  |
| ID 1                      | _                  | 54 | ID 2                              | -                  |  |
| GND                       |                    | 55 | ID 3                              | -                  |  |
| Local Clock               | _                  | 56 | ID 4                              | ACK64#             |  |
| vcc                       | -                  | 57 | Unused                            | -                  |  |
| Local Bus<br>Size 16      | -                  | 58 | Loc/Ext<br>Address Data<br>Strobe |                    |  |

## 4.4. Шина РСІ

или Slave, ЦУ).

цессора и шиной ввода/вывода ISA/EISA или МСА. Шина PCI разрабатывалась в расчете на Pentium-системы, но хорошо сочетается и с процессорами 486. Является четко стандартизованной высокопроизводительной и надежной шиной расширения. В настоящее время действует спецификация PCI 2.1. При частоте шины 33 МГц скорость теоретически достигает 132/264 Мбайт/с для 32/64 бит; при частоте синхронизации 66 МГц — в два раза выше (версия 2.1 допускает частоту до

PCI (Peripheral Component Interconnect) local bus — шина соединения периферийных компонентов. Будучи локальной, эта шина занимает особое место в современной архитектуре PC, являясь мостом (mezzanine bus) между системной шиной про-

Шина является синхронной — фиксация всех сигналов выполняется по положительному перепаду (фронту) сигнала СLК. В каждой транзакции (обмене по шине) участвуют два устройства — инициатор обмена (Initiator или Master, инициирующее устройство, ИУ) и иелевое истройство (Target

66 МГц при согласии всех устройств на шине).

Шина PCI все транзакции трактует как пакетные: каждая транзакция начинается фазой адреса, за которой может сле-

C/BE#

Сигналы разрешения байт

довать одна или несколько фаз данных. Для адреса и данных используются общие мультиплексированные линии АD. Четыре мультиплексированные линии С/ВЕ[3:0] используются для кодирования команд в фазе адреса и разрешения байт в фазе данных. В начале транзакции ИУ активизирует сигнал FRAME#, по шине AD передает целевой адрес, а по линиям С/ВЕ# — информацию о типе транзакции (команде). Адресованное ЦУ отзывается сигналом DEVSEL#, после чего ИУ может указать на свою готовность к обмену данными сигналом IRDY#. Когда к обмену данными будет готово и ЦУ, оно установит сигнал TRDY#. Данные по шине AD могут передаваться только при одновременном наличии сигналов IRDY# и TRDY#. С помощью этих сигналов ИУ и ЦУ согласуют свои скорости, вводя такты ожидания. На рис. 4.9 приведена временная диаграмма обмена, в которой и ИУ, и ЦУ вводят такты ожидания. Если бы они оба ввели сигналы готовности в конце фазы адреса и не снимали их до конца обмена, то в каждом такте после фазы адреса передавались бы по 32 бита данных, что обеспечило бы выход на предель-



данных ИУ снимает сигнал IRDY#, и шина переходит в состояние покоя (*PCI Idle*) — оба сигнала FRAME# и IRDY# находятся в пассивном состоянии. Максимальное количество ется устройством только в фазе адреса, поэтому обычно в качестве него используют старшие биты адреса с позиционным кодированием адреса устройства.

Команды шины PCI определяются значениями бит С/ВЕ# в фазе адреса в соответствии с табл. 4.5.

Таблица 45 Деконгования команды рСВ

С/ВЕ[3:0] Тип команды

О000 Іпterrupt Acknowledge — подтверждение прерывания

ется индивидуальным сигналом IDSEL#, конфигурационные регистры выбираются двойными словами по линиям AD[7:2], при этом AD[1:0]=00. Сигнал выборки IDSEL# воспринима-

Special Cycle - специальный цикл 0001 0010 I/O Read — чтение порта ввода/вывода I/O Write — запись в порт ввода / вывода 0011 0100 Зарезервировано 0101 Зарезервировано Memory Read — чтение памяти 0110 0111 Memory Write - запись в память 1000 Зарезервировано 1001 Зарезервировано Configuration Read — конфигурационное считывание 1010 Configuration Write - конфигурационная запись 1011 Multiple Memory Read - множественное чтение памяти 1100 Dual Address Cycle — двухадресный цикл 1101 Memory Read Line - чтение строк памяти 1110 1111 Memory Write and Invalidate - запись с инвалидацией В команде подтверждение прерывания контроллер прерыва-

ний передает вектор прерывания по шине AD.

Специальный цикл декодируется содержимым линий AD[15:0] и используется для указания на отключение (Shutdown), останов (Halt) процессора или специфические функции процес-

танов (*Halt*) процессора или специфические функции процессора, связанные с кэшем и трассировкой. Этим состояниям соответствуют коды 0000, 0001 и 0002; коды 0003-FFFFh за-

резервированы.

рации шинного цикла конфигурационного чтения или записи по предварительно записанному адресу. В командах *чтения и записи памяти* шина AD содержит адреса двойных слов, и линии AD0, AD1 не должны декодироваться — на конкретные байты указывают сигналы C/BE[3:0]#. Команды конфигурационного чтения и записи адресуются к конфигурационному пространству и обеспечивают доступ

к 256-байтным структурам. Обращение производится двойными словами. Структура содержит идентификатор устройства и производителя, состояние и команду, информацию об используемых ресурсах и ограничения на использование

Множественное чтение памяти используется для транзак-

ций, пересекающих границы строк кэш-памяти.

шины.

В командах *чтения и записи ввода/вывода* линии AD содержат адрес байта, причем декодированию подлежат и биты AD0 и AD1 (несмотря на то, что имеются сигналы BEx#). Порты PCI могут быть 8-, 16- или 32-битными. Для адресации портов на шине PCI доступны все 32 бита адреса, но процессоры x86 могут использовать только младшие 16 бит. Порты с адресами 0CF8 и 0CFC зарезервированы под регистры адреса и данных для доступа к конфигурационному пространству. Обращение к порту данных приведет к гене-

Двухадресный цикл применяется, когда физическая шина имеет 32 бита адреса, а требуется передача с 64-битной адресацией. В этом случае младшие 32 бита адреса передаются в цикле данного типа, а за ним следует обычный цикл, определяющий тип обмена и несущий старшие 32 бита адреса. Шина РСІ допускает 64-битную адресацию даже для портов ввода/вывода (для х86 это бесполезно, но РСІ суще-

ствует и на других платформах). Чтение строк памяти применяется, когда в транзакции планируется более двух 32-битных передач (обычно это чтение до конца строки кэша).

Запись с инвалидацией применяется к целым строкам кэша и позволяет оптимизировать циклы обратной записи «грязных» строк кэша.

чивается контактами A62/B62, 64-битный — A94/B94. На рис. 4.10 изображена 32-битная плата максимального размера (Long Card), длина короткой платы (Short Card) -6,875". Плата может иметь обрамление (скобки), стандартное для конструктива ISA или MCA. Назначение выводов универ-

Выделение специальных циклов множественного чтения, чтения строк и записи с инвалидацией позволяет контроллеру памяти предпринять определенные меры для оптими-

Слоты PCI с шагом 0.05 дюйма расположены несколько дальше от задней панели, чем ISA/EISA или MCA. Компоненты карт РСІ расположены на левой поверхности плат. По этой причине крайний РСІ-слот обычно разделяет использование посадочного места адаптера с соседним ISA-слотом (Shared slot). Шина имеет версии с питанием 5 В, 33 В и иниверсальнию (с переключением линий +V I/O с 5 В на 3,3 В). Ключами являются пропушенные ряды контактов 12, 13 и 50, 51. Для слота на 5 В ключ расположен на месте контактов 50, 51; для 3 B - 12, 13; для универсального — два ключа: 12, 13и 50. 51. Ключи не позволяют установить карту в слот с неподходящим напряжением питания. 32-битный слот закан-

зации данных передач.

сального разъема приведено в табл. 4.6, назначение сигналов — в табл. 4.7. 12.283\* 6.875" Сторона компонентов Зоны крепежа Ключ 3.3 В Ключ 5 В 0.608 4,113° Рис. 4.10. Карта расширения для шины РСІ

На одной шине РСІ может быть не более четырех устройств (следовательно, и слотов). Для подключения к другим шинам применяются специальные аппаратные средства — мос-

| вый мост (Peer-to-Peer Bridge) используется для соединения                                                      |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |                                                                   |          |
|-----------------------------------------------------------------------------------------------------------------|-------------------------------------------------------|-----------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------|-------------------------------------------------------------------|----------|
| двух шин РСІ. Несколько шин РСІ применяются в серве-                                                            |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |                                                                   |          |
| рах — это позволяет увеличить число подключаемых уст-                                                           |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |                                                                   |          |
| ройств. Для подключения шин ISA/EISA используются спе-                                                          |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |                                                                   |          |
|                                                                                                                 |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      | стемных пла                                                       |          |
|                                                                                                                 |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      | іваются диаг                                                      |          |
|                                                                                                                 |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      | івода, отведе                                                     |          |
|                                                                                                                 |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      | сущей транза                                                      |          |
|                                                                                                                 |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      | сится к ши                                                        |          |
|                                                                                                                 |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      | яет транзакці                                                     |          |
| на соответс                                                                                                     | твую                                                  | ощую шину г                                                     | и выполняет                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | деис                 | твия по согл                                                      | ia-      |
|                                                                                                                 |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      | вокупность м<br>обращений:                                        |          |
|                                                                                                                 |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      | о с конкретнь                                                     |          |
|                                                                                                                 |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      | иой из шин<br>Ной из шин                                          |          |
|                                                                                                                 |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      | ные мосты. Р                                                      |          |
|                                                                                                                 |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |                                                                   |          |
| шать задачу маршрутизации призван также сигнал DEVSEL#. Обращения, не востребованные абонентами PCI, обычно пе- |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |                      |                                                                   |          |
| Ооращения                                                                                                       | і, не в                                               | востреоовань                                                    | тые аоонента                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | ими Р                | СІ, обычно п                                                      | re-      |
|                                                                                                                 |                                                       | востреоовані<br>на шину IS                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | ими Р                | Сі, обычно п                                                      | re-      |
|                                                                                                                 |                                                       |                                                                 |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | іми Р                | СІ, обычно п                                                      | ie-      |
|                                                                                                                 | ются                                                  | на шину IS                                                      |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | іми Р                | СІ, обычно г                                                      | ie-      |
| ренаправля<br>Таблица 4.6. Ра                                                                                   | КЭТОН<br>ИМ9481                                       | на шину IS                                                      | A/EISA.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                      |                                                                   | ie-<br>1 |
| ренаправля Теблица 4.6. Ра Ряд В                                                                                | ются                                                  | на шину IS                                                      | A/EISA.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       | N#                   | Ряд А                                                             | ie-      |
| ренаправля<br>Таблица 4.6. Ра                                                                                   | КЭТОН<br>ИМ9481                                       | на шину IS                                                      | A/EISA.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |                      |                                                                   | ie-      |
| ренаправля Теблица 4.6. Ра Ряд В                                                                                | ЮТСЯ<br> <br> <br>  В В В В В В В В В В В В В В В В В | на шину IS<br>шины РСІ<br>Ряд А                                 | Pяд B PRSNT2# GND/Ключ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        | N#                   | Ряд A Reserved GND/Ключ                                           | ie-      |
| ренаправля <b>Табища 4.6. Ра Ряд В</b> 12 В <b>ТСК</b>                                                          | <b>N#</b> 1 2                                         | на шину IS<br>шины РСІ<br>Ряд А<br>ТRST#<br>+12 В               | Pяд B PRSNT2# GND/Ключ 3,3 В                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | N#<br>11<br>12       | Ряд А Reserved GND/Ключ 3,3 В                                     | ie-      |
| ренаправля <b>Таблица 4.6. Ре Ряд В</b> -12 В                                                                   | ЮТСЯ<br><b>3ъемы</b><br><b>N#</b> 1                   | на шину IS  шины РСІ  Ряд А  ТЯSТ#                              | Ряд В PRSNT2# GND/Ключ 3,3 В GND/Ключ                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         | <b>N#</b>            | Ряд А Reserved GND/Ключ 3,3 В GND/Ключ                            | ie-      |
| ренаправля <b>Таблица 4.6. Ра Ряд В</b> —12 В  ТСК  GND                                                         | <b>N#</b> 1 2                                         | на шину IS  шинь РСІ  Ряд А  ТRST# +12 В  ТMS                   | Pяд B PRSNT2# GND/Ключ 3,3 B GND/Ключ 3,3 B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | N# 11 12 13          | Ряд A Reserved GND/Ключ 3,3 B GND/Ключ 3,3 B                      | ie-      |
| ренаправля <b>Теблица 4.6. Ра Ряд В</b> — 12 В  ТСК  GND  TDO                                                   | жемы<br>жемы<br>N#<br>1<br>2<br>3<br>4                | на шину IS  шинь PCI  Ряд А  TRST# +12 B  TMS  TDI              | Ряд В PRSNT2# GND/Ключ 3,3 В GND/Ключ 3,3 В Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | N# 11 12 13          | Ряд А Reserved GND/Ключ 3,3 В GND/Ключ 3,3 В Reserved             | ie-      |
| ренаправля <b>Таблица 4.6. Ра Ряд В</b> —12 В  ТСК  GND                                                         | <b>N#</b> 1 2                                         | на шину IS  шинь РСІ  Ряд А  ТRST# +12 В  ТMS                   | Pяд B PRSNT2# GND/Ключ 3,3 B GND/Ключ 3,3 B                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | N# 11 12 13          | Ряд A Reserved GND/Ключ 3,3 B GND/Ключ 3,3 B                      | ie-      |
| ренаправля <b>Теблица 4.6. Ра Ряд В</b> — 12 В  ТСК  GND  TDO                                                   | жемы<br>жемы<br>N#<br>1<br>2<br>3<br>4                | на шину IS  шинь PCI  Ряд А  TRST# +12 B  TMS  TDI              | Ряд В PRSNT2# GND/Ключ 3,3 В GND/Ключ 3,3 В Reserved                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | N# 11 12 13          | Ряд А Reserved GND/Ключ 3,3 В GND/Ключ 3,3 В Reserved             | ie-      |
| ренаправля <b>Таблица 4.6. Ра Ряд В</b> 12 В  ТСК  GND  TDO  +5 В                                               | жемы<br>  N#                                          | Ряд A TRST# +12 B TMS TDI +5 B                                  | Ряд В РЯЗ В | N# 11 12 13 14 15    | Ряд А Reserved GND/Ключ 3,3 В GND/Ключ 3,3 В Reserved RST#        | ie-      |
| ренаправля <b>Таблица 4.6. Ра Ряд В</b> -12 В  ТСК  GND  TDO  +5 В  +5 В                                        | N#   1   2   3   4   5   6                            | на шину IS  шинь PCI  Ряд А  TRST# +12 B  TMS  TDI +5 B  INTRA# | Pяд B PRSNT2# GND/Ключ 3,3 B GND/Ключ 3,3 B Reserved GND                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      | N# 11 12 13 14 15 16 | Ряд А Reserved GND/Ключ 3,3 В GND/Ключ 3,3 В Reserved RST# +V I/O | ie-      |

AD 31

20

AD 30

Reserved

10

+V I/O

ты PCI (PCI Bridge). Главный мост (Host Bridge) используется для подключения PCI к системной шине. Одноранго-

Таблица 4.6 (продолжение) Ряд В N# Ряд А Ряд В N# Ряд А +3.3 B GND/Ключ AD 29 21 GND/Ключ 50 5 B GND/Ключ GND 22 AD 28 GND/Ключ 51 5 B 5 R C/BE0# AD 27 23 AD 26 AD 8 52 AD 25 24 AD 7 53 +3.3 B GND 25 AD 24 +3.3 B 54 AD 6 +3.3 B C/BE3# 26 IDSEL# AD 5 55 AD 4 AD 23 27 +3.3 B AD 3 56 GND GND 28 **AD 22** GND 57 AD 2 AD 21 29 AD 20 58 AD 0 AD 1 AD 19 30 **GND +V I/O** 59 **+VI/O** 31 REQ64# +3.3 B AD 18 ACK64# 60 32 **AD 17** AD 16 +5 B 61 +5 B C/BE2# 33 +3.3 B +5 B 62 +5 B 34 FRAME# Конец 32-битного разъема GND IRDY# 35 GND Reserved 63 GND +3.3 B 36 TRDY# GND 64 C/BE7# DEVSEL# 37 GND C/BE6# 65 C/BE5# STOP# C/BE4# GND 38 66 **+V I/O** LOCK# 39 +3.3 B **GND** 67 PAR64 PFRR# 40 SDONE# AD 63 68 AD 62 +3,3 B 41 SDOFF# 69 GND AD 61 SFRR# 42 **GND +V I/O** 70 AD 60 +3.3 B 43 PAR AD 59 71 AD 58 C/BE1# 44 AD 15 AD 57 72 GND AD 14 45 +3,3 B GND AD 56 73

GND

AD 12

AD 10

GND/M66EN1

46

47

48

49

**AD 13** 

AD 11

GND

AD9

AD 55

AD 53

GND

AD 51

AD 54

**+V I/O** 

AD 52

AD 50

74

75

76

77

| Ряд В           | N#         | Ряд А                                                                                                                                                                               | Ряд В                                          | N#      | Ряд А       |  |
|-----------------|------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------|---------|-------------|--|
| AD 49           | 78         | GND                                                                                                                                                                                 | AD 37                                          | 87      | GND         |  |
| +V I/O          | 79         | AD 48                                                                                                                                                                               | +V I/O                                         | 88      | AD 36       |  |
| AD 47           | 80         | AD 46                                                                                                                                                                               | AD 35                                          | 89      | AD 34       |  |
| AD 45           | 81         | GND                                                                                                                                                                                 | AD 33                                          | 90      | GND         |  |
| GND             | 82         | AD 44                                                                                                                                                                               | GND                                            | 91      | AD 32       |  |
| AD 43           | 83         | AD 42                                                                                                                                                                               | Reserved                                       | 92      | Reserved    |  |
| AD 41           | 84         | +V I/O                                                                                                                                                                              | Reserved                                       | 93      | GND         |  |
| GND             | 85         | AD 40                                                                                                                                                                               | GND                                            | 94      | Reserved    |  |
| AD 39           | 86         | AD 38                                                                                                                                                                               | Конец 64-битн                                  | ого раз | въема       |  |
| 1 Сигнал М6     | 6EN o      | пределен в РС                                                                                                                                                                       | 2.1.                                           |         |             |  |
| Таблица 4.7. Си | nens i     | вины РСІ                                                                                                                                                                            |                                                |         |             |  |
| Сигнал          | Наз        | начение                                                                                                                                                                             |                                                |         |             |  |
| AD[31:0]        | ca/        | данных. В                                                                                                                                                                           | ультиплексиро<br>начале транз<br>ощих тактах — | акции   | передается  |  |
| C/BE[3:0]#      | щен<br>ред | Command/Byte Enable — команда/разрешение обра-<br>щения к байтам. Команда, определяющая тип оче-<br>редного цикла шины, задается четырехбитным<br>кодом в фазе адреса               |                                                |         |             |  |
| FRAME#          | зак:<br>на | Кадр. Введением сигнала отмечается начало тран-<br>закции (фаза адреса), снятие сигнала указывает<br>на то, что последующий цикл передачи данных<br>является последним в транзакции |                                                |         |             |  |
| DEVSEL#         |            |                                                                                                                                                                                     | устройство вы<br>ему транзакции                |         | (ответ ЦУ   |  |
| IRDY#           | Init       | iator Ready — 1                                                                                                                                                                     | отовность ИУ                                   | к обме  | ену данными |  |
| TRDY#           | Taŋ        | get Ready — ro                                                                                                                                                                      | товность ЦУ к                                  | обмен   | у данными   |  |
| STOP#           | Зап        | рос ЦУ к ИУ                                                                                                                                                                         | на останов тек                                 | ущей :  | гранзакции  |  |
| LOCK#           |            | Используется для установки, обслуживания и освобождения захвата ресурса PCI                                                                                                         |                                                |         |             |  |
| REQ#            | Req        | Request — запрос от РСІ-мастера на захват шины                                                                                                                                      |                                                |         |             |  |
| GNT#            | Gra        | nt — предостав                                                                                                                                                                      | ление мастеру у                                | правле  | ения шиной  |  |
| PAR             |            | ty — общий б<br>/BE[3:0]                                                                                                                                                            | ит паритета дл                                 | ія лин  | ий AD[31:0] |  |

| Сигнал      | Назначение                                                                                     |
|-------------|------------------------------------------------------------------------------------------------|
| PERR#       | ParityError — сигнал об ошибке паритета (от устрой ства, ее обнаружившего)                     |
| PRSNT[1,2]# | Present — индикаторы присутствия платы, коди-<br>рующие запрос потребляемой мощности           |
| RST#        | Reset — сброс всех регистров в начальное состояние                                             |
| IDSEL#      | Initialization Device Select — выбор устройства в циклах конфигурационного считывания и записи |

REQ64#

SERR

ACK64#

INTRA# INTRB#

INTRC#

System Error — системная ошибка. Активизируется любым устройством PCI и вызывает NMI Request 64 bit — запрос на 64-битный обмен

Подтверждение 64-битного обмена Internux A, B, C, D — линии запросов прерывания. Циклически сдвигаются в слотах и направляются на доступные линии IRQ. Запрос по низкому уровню допускает разделяемое использование линий

INTRD# CLK Clock – тактовая частота шины. Должна быть в пределах 20-33 МГц, в PCI 2.1 - до 66 МГц M66FN 66MHzEnable — разрешение частоты синхронизации до 66 МГи Snoop Done - сигнал завершенности цикла слежения для текущей транзакции. Низкий уровень указывает

SDONE на незавершенность цикла слежения за когерентностью памяти и кэша. Необязательный сигнал, используется только устройствами шины с кэшируемой памятью SBO# Snoop Backoff - попадание текущего обращения к памяти абонента шины в модифицированную строку

кэша. Необязательный сигнал, используется только абонентами шины с кэшируемой памятью алгоритме обратной записи TCK TDI

Test Clock — синхронизация тестового интерфейса **JTAG** TDO

Test Data Input – входные данные тестового интерфейса JTAG Test Data Output — выходные данные тестового интерфейса JTAG

Test Mode Select — выбор режима для тестового

интерфейса JTAG TRST Test Logic Reset — сброс тестовой логики PCI Transferring. Эта возможность реализуется не всеми чипсетами (в описаниях она всегда специально подчеркивается), а обычными устройствами (видеокарты и контроллеры дисков) используется редко.

С мостами PCI/ISA связано понятие VGA Palette Snooping, которое обеспечивает исключение из правила однозначной

маршрутизации обращений. Графическая карта в компью-

Одной из особенностей шины PCI является возможность обмена данными между процессором и памятью одновременно с обменом между другими устройствами PCI — Concurrent

тере с шиной PCI обычно устанавливается на шину PCI. На VGA-карте имеются регистры палитр (Palette Registers), приписанные к пространству ввода/вывода. Если графическая система содержит еще и карту смешивания сигналов графического адаптера с сигналом «живого видео», перехватывая двоичную информацию о цвете текущего пиксела по шине VESA Feature Connector (снимаемую до регистра палитр), цветовая гамма будет определяться регистром палитр, размещенным на этой дополнительной карте. Возникает ситуация, когда операция записи в регистр палитр должна отра-

батываться одновременно и в графическом адаптере (на шине PCI), и в карте видеорасширения, которая часто размещается на шине ISA. В BIOS Setup может присутствовать опция PCI VGA Palette Snoop. При ее разрешении запись в порты ввода/вывода по адресу регистра палитр будет вызывать транзакцию как на шине PCI, так и на шине ISA, чтение же

по этим адресам будет выполняться только PCI. Реализация может возлагаться на графическую карту PCI. Для этого она во время записи в регистр палитр фиксирует данные, но сигналы квитирования DEVSEL# и TRDY# не вырабатывает, в результате чего мост распространяет этот неопознанный запрос на шину ISA. В других реализациях мосту явно указывают на данное исключение, и он сам распространяет запись в регистры палитр на шину ISA.

Автоконфигурирование устройств (выбор адресов и преры-

ваний) поддерживается средствами BIOS и ориентировано на технологию Plug and Play. Стандарт PCI определяет для каждого слота конфигурационное пространство размером до 256 8-битных регистров, не приписанных ни к простран-

нах памяти. После распределения ресурсов, выполняемого программой конфигурирования (во время POST), в устройства записываются параметры конфигурирования. Только после этого к устройствам становится возможным доступ по командам обращения к памяти и портам ввода/вывода. Для ПЗУ расширения BIOS, установленных на картах PCI, принят стандарт, несколько отличающийся от традиционных дополнительных модулей ROM BIOS. Поскольку шина РСІ используется не только в РС, в ПЗУ карты может храниться несколько модулей. Тип платформы (процессора) указывается в заголовке модуля, и при инициализации BIOS активизируется нужный. Такой механизм позволяет, например, один и тот же графический адаптер устанавливать и в IBM PC, и в Power PC. В состав шины РСІ введены сигналы для тестирования адаптеров по интерфейсу *JTAG*. На системной плате эти сигналы задействованы не всегда, но они могут и организовывать ло-

Некоторые фирмы выпускают для РСІ карты-прототипы, но доукомплектовать их адаптером собственной разработки сложнее, чем карту ISA. Здесь сказываются сложные прото-

Слот РСІ достаточен для подключения адаптера (в отличие от VLB), на системной плате он может сосуществовать с любой из шин ввода/вывода и даже с VLB. На некоторых системных платах позади одного из слотов РСІ имеется разъем Media Bus, на который выводятся сигналы ISA. Он

гическую цепочку тестируемых адаптеров.

колы и высокие частоты,

ству памяти, ни к пространству ввода/вывода. Доступ к ним осуществляется по специальным циклам шины Configuration Read и Configuration Write, вырабатываемым контроллером при обращении процессора к регистрам контроллера шины PCI, расположенным в его пространстве ввода/вывода. После аппаратного сброса (или по включении питания) устройства PCI не отвечают на обращения к пространству памяти и ввода/вывода, они доступны только для операций конфигурационного считывания и записи. В этих операциях устройства выбираются по индивидуальным сигналам IDSEL# и сообщают о потребностях в ресурсах и возможных диапазо-

Для *устройств промышленного назначения* в начале 1995 г. был принят стандарт Compact PCI. Шина Compact PCI (cPCI) разрабатывалась на основе спецификации РСІ 2.1. Эта шина отличается большим количеством поддерживаемых слотов: 8 против 4. Появились новые 4 пары сигналов запросов и предоставления управления шиной. Шина поддерживает 32-битный и 64-битный обмен (с индивидуальным разрешением байт). При частоте шины 33 МГц максимальная пропускная способность составляет 133 Мбайт/с для 32 бит и 266 Мбайт/с для 64 бит (в середине пакетного цикла). Возможна работа на частоте 66 МГц. Шина поддерживает спецификацию PnP. Кроме того, в шине возможно применение географической адресации, при этом адрес модуля (на который он отзывается при программном обращении) определяется его положением в каркасе. Для этого на коннекторе 11 имеются контакты GA0...GA4, коммутацией которых на «землю» для каждого слота задается его двоичный адрес. Географическая адресация позволяет переставлять однотипные модули, не заботясь о конфигурировании их адресов (хорошая альтернатива системе PnP — модуль «встанет» всегда в одни и те же адреса, которые без физического вмешательства больше не изменятся). Конструктивно платы Compact PCI представляют собой еврокарты высотой 3U (100×160 мм) с одним коннектором (J1) или 6U (233×160 мм) с двумя коннекторами (J1 и J2). Коннекторы — 7-рядные штырьковые разъемы с шагом 2 мм между контактами, на кросс-плате вилка, на модулях — розетки. Контакты коннекторов имеют разную длину: более длинные контакты цепей питания при установке модуля соединяются раньше, а при вынимании разъединяются позже, чем сигнальные. Такое решение по-

используется для размещения на графическом адаптере РСІ

звукового чипсета, предназначенного для шины ISA.

но шина использует только один коннектор (J1), причем в 32-битном варианте не полностью — часть контактов может задействовать пользователь. 64-битная шина использует коннектор полностью. Одно посадочное место на кроссплате резервируется под контроллер шины, на который возлагаются функции арбитража и синхронизации. На его

зволяет производить «горячую» замену модулей. Собствен-

дификации (например, с разделяющим экраном и механическими ключами). В шине предусматривается наличие независимых источников питания +5 B, +3.3 B и  $\pm 12$  B. На базе шины Compact PCI фирмой National Instruments разработана спецификация PXI (PCI eXtensions for Instrumentation — расширение PCI для инструментальных систем) в тех же конструктивах. В шине РХІ часть контактов, определенных в Compact PCI как свободно используемые, предназначается для дополнительных шин. Шина Trigger Bus (8 линий) звездообразно соединяет слот своего контроллера (первый после системного контроллера РСІ) с остальными слотами. Шина позволяет осуществлять синхронизацию разных модулей, что зачастую требуется в измерительных системах. Для прецизионной синхронизации имеется сигнал опорной частоты 10 МГц РХІ СLК, который звездообразно (с одинаковыми задержками распространения сигнала) разводится по слотам. В РХI определены локальные шины, предназначенные для связи соседних пар слотов. Каждая локальная шина имеет 13 линий, которые могут использоваться как для цифровых, так и для аналоговых (до 48 В) сигналов. Локальные шины объединяют смежные слоты попарно (исключая слот системного контроллера), образуя цепочку. Кроме механических и электрических характеристик РХІ определяет ПО модулей: основной ОС считается Windows NT/95, и модули должны поставляться с соответствующими драйверами. Это экономит время, необходимое для системной интеграции. Модули PXÎ совместимы с шиной Compact PCI, и модули Compact PCI - с шиной РХІ. Однако все преимущества спецификации реализуются только при установке модулей РХІ в щину РХІ. 4.5. Магистральный интерфейс AGP В настоящее время самой быстрой универсальной шиной расширения является РСІ, имеющая при тактовой частоте

коннекторе шиной используется большее число контактов, чем на остальных. У больших плат коннектор J2 предоставляется пользователю, а между коннекторами J1 и J2 может устанавливаться 95-контактный коннектор J3. Конструкция коннекторов позволяет для J2 применять специфические мо-

ния к пропускной способности шины, связывающей дисплейный адаптер с памятью и центральным процессором компьютера, повышаются. Одно из решений состоит в уменьшении потока графических данных, передаваемых по шине. Для этого графические платы снабжают акселераторами и увеличивают объем видеопамяти, которой пользуется акселератор при выполнении построений. В результате поток

66 МГц и разрядности 32 бит пиковую пропускную способность 264 Мбайт/с. Одним из главных потребителей пропускной способности шины является графический адаптер. По мере увеличения разрешения и глубины цвета требова-

данных в основном циркулирует внутри графической карты, слабо нагружая внешнюю шину. Однако при трехмерных построениях акселератору становится тесно в ограниченном объеме видеопамяти, и его поток данных снова выплескивается на внешнюю шину. Фирма Intel на базе шины PCI 2.1 разработала новый стандарт подключения графических адаптеров -AGP (Accelerated Graphic Port — ускоренный графический порт). Этот порт представляет собой 32-разрядную шину с тактовой частотой 66 МГц, по составу сигналов (табл. 4.8) напоминающую шину PCI. Чипсет системной платы связывает AGP с памятью и системной шиной процессора, не пересекаясь с «узким местом» — шиной РСІ. «Ускоренность» порта обеспечивается следующими факторами:

сдвоенной передачей данных;

конвейеризацией обращений к памяти;

демультиплексированием шин адреса и данных.

Конвейеризацию обращений памяти

иллюстрирует К рис. 4.11, где сравниваются обращения к памяти РСІ и АGР.

В РСІ во время реакции памяти на запрос шина простаи-

вает. Конвейерный доступ АСР позволяет в это время передавать следующие запросы, а потом получить поток от-

ветов. АСР предусматривает постановку в очередь до 256 запросов, но при конфигурировании по PnP реальные возможности конкретной системы уточняются (возможности

контроллера памяти ограничены). АGР поддерживает две пары очередей для операций записи и чтения из памяти с

высоким и низким приоритетами. В передачу данных любого запроса может вмешаться следующий запрос, в том числе запрос в режиме РСІ.

| Таблица 4.8. | CHESTIC | nuchta wat. |          |    |             |
|--------------|---------|-------------|----------|----|-------------|
| Ряд А        | Nº      | Ряд В       | Ряд А    | Nº | Ряд В       |
| Spare        | 1       | 12V         | Vddq3.3  | 34 | Vddq3.3     |
| 5.0V         | 2       | Spare       | AD21     | 35 | AD22        |
| 5.0V         | 3       | Reserved    | AD19     | 36 | AD20        |
| USB+         | 4       | USB-        | GND      | 37 | GND         |
| GND          | 5       | GND         | AD17     | 38 | AD18        |
| INTB#        | 6       | INTA#       | C/BE2#   | 39 | AD16        |
| CLK          | 7       | RST#        | Vddq3.3  | 40 | Vddq3.3     |
| REQ#         | 8       | GNT#        | IRDY#    | 41 | FRAME#      |
| VCC3.3       | 9       | VCC3.3      |          | 42 |             |
| ST0          | 10      | ST1         | GND      | 43 | GND         |
| ST2          | 11      | Reserved    |          | 44 |             |
| RBF#         | 12      | PIPE#       | VCC3.3   | 45 | VCC3.3      |
| GND          | 13      | GND         | DEVSEL#  | 46 | TRDY#       |
| Spare        | 14      | Spare       | Vddq3.3  | 47 | STOP#       |
| SBA0         | 15      | SBA1        | PERR#    | 48 | Spare       |
| VCC3.3       | 16      | VCC3.3      | GND      | 49 | GND         |
| SBA2         | 17      | SBA3        | SERR#    | 50 | PAR         |
| SB_STB       | 18      | Reserved    | C/BE1#   | 51 | AD15        |
| GND          | 19      | GND         | Vddq3.3  | 52 | Vddq3.3     |
| SBA4         | 20      | SBA5        | AD14     | 53 | AD13        |
| SBA6         | 21      | SBA7        | AD12     | 54 | AD11        |
| KEY          | 22      | KEY         | GND      | 55 | GND         |
| KEY          | 23      | KEY         | AD10     | 56 | AD9         |
| KEY          | 24      | KEY         | AD8      | 57 | C/BE0#      |
| KEY          | 25      | KEY         | Vddq3.3  | 58 | Vddq3.3     |
| AD31         | 26      | AD30        | AD_STB() | 59 | Reserved    |
| AD29         | 27      | AD28        | AD7      | 60 | AD6         |
| VCC3.3       | 28      | VCC3.3      | GND      | 61 | GND         |
| AD27         | 29      | AD26        | AD5      | 62 | AD4         |
| AD25         | 30      | AD24        | AD3      | 63 | AD2         |
| GND          | 31      | GND         | Vddq3.3  | 64 | Vddq3.3     |
| AD_STB1      | 32      | Reserved    | AD1      | 65 | AD0         |
|              | 1       | 1           |          | +  | <del></del> |

AD23

33

C/BE3#

SMB<sub>0</sub>

66

SMB<sub>1</sub>



Рис. 4.11. Циклы обращения к памяти PCI и AGP Сдвоенная передача данных обеспечивает при частоте 66 МГц

пропускную способность до 532 Мбайт/с, что для 32-битной шины неожиданно. В AGP кроме «классического» режима, называемого теперь «x1», в котором за один такт синхронизации передается один 4-байтный блок данных, есть режим «x2», когда блоки данных передаются как по фронту, так и по спаду сигнала синхронизации (как в ATA Ultra DMA). Управление передачей в таком режиме названо SideBand Control (приставка SB к имени сигнала). Заказать режим x2 может только графическая карта, если она его поддерживает. При переходе на тактовую частоту 100 МГц пропускная способность повышается до 800 Мбайт/с. Демультиплексирование (разделение) шины адреса и данных

сделано несколько необычным образом. Демультиплексирование подразумевает наличие двух полноразрядных шин адреса и данных. Однако такой вариант дорог. Поэтому шину адреса в демультиплексированном режиме АСР представляют 8 линий SBA (SideBand Address), по которым за три такта синхронизации передаются четыре байта адреса, длина запроса (1 байт) и команда (1 байт). За каждый такт передаются по два байта — один по фронту, другой по спаду тактового сигнала. Поддержка демультиплексированной адресации не является обязательной для карты AGP. Требуется также поддержка хост-контроллера. Альтернативным способом подачи адреса является обычный — по мультиплексированной шине AD.

AGP может реализовать всю пропускную способность 64-битной системы памяти компьютера на процессорах Pentium и выше. При этом возможны конкурирующие обращения к шин PCI.
Порт AGP может работать как в своем «естественном» режиме с конвейеризацией и сдвоенными передачами, так и в

памяти как со стороны процессора, так и со стороны мостов

режиме шины PCI. В конвейеризированном режиме, в котором начало цикла отмечается сигналом PIPE#, возможны только обращения к памяти. В режиме PCI циклы начинаются с сигнала FRAME#, и обращения возможны как к про-

странству памяти, так и к пространству ввода/вывода и конфигурационному пространству. Кроме собственно AGP, в порте AGP заложены сигналы шины USB, которую предполагается заводить в монитор. Внешне карты с портом AGP

похожи на PCI, но у них используется разъем повышенной плотности с «двухэтажным» (как у EISA) расположением ламелей. Сам разъем располагается дальше от задней кромки платы, чем разъем PCI.

Фирма Intel ввела поддержку AGP в чинсеты для процессо-

ний» для применения AGP с Pentium.
AGP строился исключительно для графического акселератора. Порт позволяет работать в двух режимах — DMA и исполнения (Executive Mode). В режиме DMA акселератор

ров Pentium Pro и Pentium II. Однако нет «противопоказа-

исполнения (Executive Mode). В режиме DMA акселератор при вычислениях рассматривает видеонамять как первичную, а когда ее недостаточно, подкачивает данные из основной памяти. При этом для трафика порта характерны длительные блочные передачи. В режиме DIME (Direct Memory Execute) видеопамять и основная память для акселератора равнозначны и располагаются в едином адресном пространстве. Трафик порта при этом будет насыщен короткими про-

извольными запросами.
Отметим, что многие преимущества АСР носят потенциальный характер и могут быть реализованы лишь при поддержке аппаратных средств графического адаптера и ПО. Что каса-

ется большой пропускной способности AGP, то следует напомнить, что в графических адаптерах с памятью WRAM или RDRAM внутренняя скорость обмена данными акселератора с видеопамятью достигает 1,6 Гбайт/с, так что DIME

выигрывает только за счет объема доступной памяти.

### 4.6. Шины PCMCIA (PC Card)

Организация PCMCIA (Personal Computer Memory Card International Association — международная ассоциация производителей карт памяти для персональных компьютеров) ввела ряд стандартов на шины расширения блокнотных компьютеров. Первый из них назывался *PCIMCIA*. Впоследствии он был переименован в PC Card. Шина PC Card позволяет подключать расширители памяти, модемы, контроллеры дисков и стриммеров, SCSI-адаптеры, сетевые адаптеры и т. д. Недостаточно строгое следование производителей этому стандарту приводит к проблемам совместимости. Назначение контактов разъема шины приведено в табл. 4.9. Шина адресует 64 Мбайт памяти, разрядность данных 16 бит, частота до 33 МГц, DMA и Bus-Mastering не поддерживаются. Теоретически допускается до 4080 слотов PC Card. Шина ориентирована на программное конфигурирование адаптеров. Большинство адаптеров выпускаются с поддержкой PnP и предусматривают «горячее» подключение — интерфейсные карты могут вставляться и выниматься без выключения компьютера. Для этого контакты шин питания имеют большую длину, чем сигнальные, чем обеспечивается их упреждающее подключение и запаздывающее отключение. Два контакта обнаружения карты (Card Detect) короче остальных. Все устройства имеют свою поддержку BIOS. Несмотря на возможность динамического конфигурирования, в некоторых случаях при изменении конфигурации требуется перезагрузка системы.

Различают 4 типа РС Card. Электрически идентичные, они варьируются по габаритам при совместимости снизу вверх (меньшие адаптеры встают в большие гнезда). Адаптер типа 1 имеет размеры 54×85 мм и толщину не более 3,3 мм, типа 2—48×75 мм и толщину 5 мм, типа 3 толщину 10,5 мм (однако HDD типа 3 имеет толщину 13 мм!).

Все устройства PC Card имеют минимальное энергопотребление. Существуют предпосылки для введения этой шины как дополнительной в настольные PC.

Шина *CardBus* с тем же 68-контактным разъемом обеспечивает расширение разрядности данных до 32 бит за счет муль-

типлексирования шины адреса и данных, обеспечивая обратную совместимость с PC Card.

Data 10

GND

Card Detect 2#

# Таблица: 4,9. Резъем шины PC Card (PCMCIA)

Data 2

GND

WRProt/(IOCS16#)

32

33

| Контакт | Сигнал             | Контакт     | Сигнал             |
|---------|--------------------|-------------|--------------------|
| 1       | GND                | 35          | GND                |
| 2       | Data 3             | 36          | Card Detect 1#     |
| 3       | Data 4             | 37          | Data 11            |
| 4       | Data 5             | 38          | Data 12            |
| 5       | Data 6             | 39          | Data 13            |
| 6       | Data 7             | 40          | Data 14            |
| 7       | Card Enable 1#     | 41          | Data 15            |
| 8       | Addr 10            | 42          | Card Enable 2#     |
| 9       | Out Enable#        | 43          | Refresh            |
| 10      | Addr 11            | 44          | RFU (IOR#)         |
| 11      | Addr 9             | 45          | RFU (IOW#)         |
| 12      | Addr 8             | 46          | Addr 17            |
| 13      | Addr 13            | 47          | Addr 18            |
| 14      | Addr 14            | 48          | Addr 19            |
| 15      | WrEnable#/Prog#    | 49          | Addr 20            |
| 16      | Ready/Busy# (IREQ) | 50          | Addr 21            |
| 17      | +5 B               | 51          | +5 B               |
| 18      | Vpp1               | 52          | Vpp2               |
| 19      | Addr 16            | 53          | Addr 22            |
| 20      | Addr 15            | 54          | Addr 23            |
| 21      | Addr 12            | 55          | Addr 24            |
| 22      | Addr 7             | 56          | Addr 25            |
| 23      | Addr 6             | 57          | RFU                |
| 24      | Addr 5             | 58          | Reset              |
| 25      | Addr 4             | 59          | WAIT#              |
| 26      | Addr 3             | 60          | RFU (INPACK#)      |
| 27      | Addr 2             | 61          | Register Select#   |
| 28      | Addr 1             | 62          | BatVDet2 (SPKR#)   |
| 29      | Addr 0             | 63          | BatVDet1 (STSCHG#) |
| 30      | Data 0             | 64          | Data 8             |
| 31      | Data 1             | 65          | Data 9             |
|         | <del></del>        | <del></del> | <del></del>        |

66

67

68

Для карт памяти (динамической, статической, постоянной и флэш-памяти) существует стандарт Miniature Card, прелставляющий подмножество шины PC Card. Миниатюрная карта размером 33×38×3,5 мм с 60-контактным разъемом через переходный адаптер может устанавливаться и в слот PC Card типа 2.

## 5. Шина SCSI

Системный интерфейс малых компьютеров SCSI (Small Computer System Interface, произносится «скази») был стандартизован ANSI в 1986 году (X3.131-1986). Интерфейс предназначен для соединения устройств различных классов - папрямого (жесткие диски) и последовательного (стриммеры) доступа, CD-ROM, оптических дисков однократной и многократной записи, устройств автоматической смены носителей информации, принтеров, сканеров, коммуникационных устройств и процессоров. Устройством SCSI — SCSI Device — называется как хост-адаптер, связывающий шину SCSI с какой-либо внутренней шиной компьютера, так и контроллер целевого устройства — target controller, с помощью которого оно подключается к шине SCSI. С точки зрения шины все устройства могут быть равноправными и являться как инициаторами обмена (инициализирующими устройствами, ИУ), так и целевыми устройствами (ЦУ), однако чаще всего в роли ИУ выступает хост-адаптер. К одному контроллеру может подключаться несколько ПУ, по отношению к которым контроллер может быть как внутренним, так и внешним. Широкое распространение получили ПУ со встроенным контроллером SCSI (embeded SCSI controller), к которым относятся накопители на жестких магнитных дисках, CD-ROM, стриммеры. Каждое ЦУ может содержать до

8 независимо адресуемых логических устройств (ЛУ) со своими номерами LUN (Logical Unit Number), представляющими ПУ или их части. По физической реализации интерфейс является 8-битной параллельной шиной с тактовой частотой 5 МГц. Скорость передачи данных достигает 5 Мбайт/с. Впоследствии появилась спецификация — SCSI-2 (X3.131-1994), расширяющая возможности шины. Тактовая частота шины Fast (бы-

ющая возможности шины. Тактовая частота шины Fast (быстрый) SCSI-2 достигает 10 МГц, а  $Ultra\ SCSI-2\ -20$  МГц. Разрядность данных может быть увеличена до 16 бит — эта версия называется Wide (широкий) SCSI-2, а 8-битную вер-

работы друг от друга обусловливают высокую эффективность применения SCSI в многозадачных системах. Возможность присутствия на шине более одного контроллера (инициатора обмена) позволяет обеспечить разделяемое использование периферии несколькими компьютерами, подключенными к одной шине. SCSI-3 — дальнейшее развитие стандарта, направленное на увеличение количества подключаемых устройств, расширение системы команд и поддержку Plug and Play. В качестве альтернативы параллельному интерфейсу SPI (SCSI-3 Parallel Interface) появляется возможность применения последовательного, в том числе волоконно-оптического, интерфейса

со скоростью 100 Мбайт/с. SCSI-3 существует в виде широкого спектра документов, определяющих отдельные аспекты интерфейса. Архитектурная модель SAM (SCSI-3 Architecture Model) изображена на рис. 5.1. Первичный набор общих команд SCP (SCSI-3 Primary Commands) для устройств различных классов дополняется набором команд со-

сию стали называть Narrow (узкий). 16-битная шина допускает 16 устройств. Стандарт SCSI-2 определяет 32-битную версию интерфейса, но такие устройства обладают неоправданно высокой стоимостью интерфейса. Спецификация SCSI-2 определяет систему команд, которая включает набор базовых команд CCS (Common Command Set), обязательных для всех ПУ, и специфических команд для периферии различных классов. Стандарт полностью описывает протокол взаимодействия устройств, включая структуры передаваемой информации. Поддержка устройствами исполнения цепочек команд (до 256 команд) и независимость их

SBC (SCSI-3 Block Commands) — для устройств памяти прямого доступа, SSC (SCSI-3 Stream Commands) — для устройств памяти

ответствующего класса устройств:

ройств смены носителей,

последовательного доступа,

SGC (SCSI-3 Graphic Commands) — для принтеров и сканеров,

SMC (SCSI-3 Medium Changer Commands) — для уст-

- циклов данных в пакете может быть неявно ограничено таймером, определяющим максимальное время, в течение которого ИУ может пользоваться шиной. ИУ завершает транзакцию одним из следующих способов:

  « Нормальное завершение выполняется по окончании об-
- Завершение по тайм-ауту (*Time-out*) происходит, когда во время транзакции у ИУотбирают право на управление шиной (снятием сигнала GNT#) или когда истекает время, указанное в его таймере MLT (медленное ЦУ или

мена ланными.

- слишком длинная транзакция).

  Транзакция отвергается (*Abort*), когда в течение заданного времени ИУ не получает ответа ЦУ (DEVSEL#).

  Транзакция может быть прекращена и по инициативе ЦУ,
- Отключение (*Disconnect*) сигнал этом вводится во время активности TRDY#. В этом случае транзакция завершается после фазы данных.
   Отключение с повтором (*Disconnect/Retry*) сигнал
- снятием DEVSEL# (в предыдущих случаях во время появления сигнала STOP# сигнал DEVSEL# был активен). В этом случае последняя фаза данных тоже отсутствует, но повтор не запрашивается.

  Протокол квитирования обеспечивает надежность обмена—
- Протокол квитирования обеспечивает надежность обмена ИУ всегда получает информацию об отработке транзакции ЦУ. Средством повышения надежности (достоверности) является применение контроля паритета: линии AD[31:0] и
- ляется применение контроля паритета: линии AD[31:0] и C/BE#[3:0] и в фазе адреса, и в фазе данных защищены битом паритета РАР (количество единичных бит этих линий, включая РАР, должно быть четным). Действительное значение РАР появляется на шине с задержкой в один такт относительно линий AD и C/BE#. При обнаружении ошибки ЦУ со сдви-

ление шиной и GNT# для подтверждения предоставления управления шиной. Схема приоритетов (фиксированный, циклический, комбинированный) определяется программированием арбитра.

Каждое устройство — потенциальное ИУ (PCI Master) — имеет собственный программируемый таймер MLT (Master)

гом на такт вырабатывается сигнал PERR#. В подсчете паритета при передаче данных учитываются все байты, включая и недействительные (отмеченные высоким уровнем сигнала С/ВЕ#і). Состояние бит и недействительных байт данных во

Арбитражем запросов на использование шины занимается специальный узел, входящий в чипсет системной платы. Каждое ИУ имеет пару сигналов — REQ# для запроса на управ-

время фазы данных должно оставаться стабильным.

Latency Timer), определяющий максимальное количество тактов шины, допустимое для одной транзакции. Его конфигурированием осуществляется распределение полосы пропускания шины между устройствами.

Каждое ЦУ имеет инкрементный механизм слежения за дли-

кания шины между устройствами. Каждое ЦУ имеет *инкрементный механизм слежения* за длительностью циклов (*Incremental Latency Mechanism*), который не позволяет интервалу между соседними фазами данных в пакете превышать 8 тактов шины. Если ЦУ не успевает ра-

ботать в таком темпе, оно обязано остановить транзакцию. Адресация памяти, портов и конфигурационных регистров различна. Байты шины АD, несущие действительную информацию, выбираются сигналами С/ВЕ[3:0] в фазах данных (внутри пакета эти сигналы могут менять состояние). В цик-

лах обращения к памяти адрес, выровненный по границе двойного слова, передается по линиям AD[31:2], линии

- ж от чередование адресов с учетом длины строки кэш памяти;

В циклах обращения к портам ввода/вывода для адресации любого байта используются все линии AD[31:0]. В циклах конфигурационной записи/считывания устройство выбира-

леров. *Транспортный уровень* может использовать различные протоколы с соответствующей поддержкой *физических соедине-*

SCC (SCSI-3 Controller Commands) — для хост-контрол-

- диционного интерфейса, физически реализуемый интерфейсом *SPI*.

  \*\* *FCP* (Fibre Channel Protocol) протокол оптоволоконно-
- го канала с соответствующим физическим уровнем *FC-PH*.

  \*\* *SBP* (Serial Bus Protocol) протокол последовательной шины, реализуемый интерфейсом 1394 (FireWire).

  \*\* *GPP* (Generic Packetized Protocol) обобщенный пакет-
- ный протокол, реализуемый любым пакетным интерфейсом.

  \*\* SSP (Serial Storage Protocol) — последовательный прото-
- кол памяти, реализованный на архитектуре последовательной памяти SSA (Serial Storage Architecture).

  К примеру, дисковый накопитель SCSI-3 с параллельным

интерфейсом описывает набор стандартов SPI+SIP+SAM+SPC+SBC, а для того же устройства, но с последовательным интерфейсом вместо SPC+SBC будет связка FCP+FC-PH. Заявка о поддержке устройством стандарта SCSI-3 непосредственно на повышение производительности по сравнению со SCSI-2 не указывает. Однако устройства SCSI-3 в большинстве случаев показывают более высокую произво-



**Рис. 5.1.** Архитектурная модель SCSI-3

в секунду — MT/c (Mega Transfer/sec), и разрядностью. Комбинации частоты и разрядности обеспечивают широкий диапазон пропускной способности (табл. 5.1), достигающей 80 Мбайт/с для версии Ultra2 Wide SCSI. SCSI Fast означает частоту передач 10 МТ/с, временные диаграммы для такого режима определены в SCSI-2. Название SCSI Fast-20 указывает на частоту передач 20 МТ/с. Этот режим, более извест-

Для параллельных шин скорость передачи данных определяется частотой передач, измеряемой в миллионах передач

ный как SCSI Ultra, определен для параллельного интерфейса в SCSI-3. SCSI Fast-40 указывает на частоту передач 40 MT/с. Этот режим, определенный в SCSI-3 и называемый Ultra2 SCSI, в настоящее время является самым быстрым для параллельной шины. Он реализован только в низковольтной дифференциальной версии интерфейса — LVD. В SCSI-3 предусмотрен режим SCSI Fast-80.

Для Narrow SCSI использовался разъем, изображенный на рис. 5.2. Wide SCSI использует разъем, изображенный на рис. 5.3. Для устройств с «горячей» заменой применяют миниатюрный D-образный разъем SCA-2, общий для питания и сигнальных цепей (рис. 5.4).



50-Pin SCSI-Bus Interface Connector



Рис. 5.3. Разъем 16-битного устройства SCSI

80-Pin SCSI SCA Connector Pin 1

Рис. 5.4. Разъем устройства SCSI с «горячей» заменой

| Разрядность | Разновидность |      |                 |                  |  |
|-------------|---------------|------|-----------------|------------------|--|
| шины, бит   | Обычный       | Fast | Fast-20 (Ultra) | Fast-40 (Ultra2) |  |
| 8 (Narrow)  | 5             | 10   | 20              | 40               |  |
| 16 (Wide)   | 10            | 20   | 40              | 80               |  |
| 32 (Wide)*  | 20            | 40   | 80              | 160              |  |

<sup>•</sup> Реализации не встречаются.

Последовательный интерфейс *FCAL* (Fibre Channel Arbitrated Loop — кольцо волоконного канала с арбитражем) по реализации ближе к интерфейсам локальных сетей. Этот интерфейс, известный также как *Fibre Channel SCSI*, может иметь как электрическую (коаксиальный кабель), так и оптоволоконную реализацию. В обоих случаях частота 1 ГГц обеспечивает скорость передачи данных 100 Мбайт/с. Медный кабель допускает длину шины до 30 м, оптический — до 10 км. Здесь используются иные протокольный и физический уровни интерфейса и имеется возможность подключения 126 устройств.

В настоящее время наибольшее распространение имеют устройства SCSI-2, которые сохраняют совместимость с исходной версией, теперь называемой SCSI-1. Однако смешивать устройства SCSI-1 и SCSI-2 неэффективно, да и не всегда возможно из-за проблем, о которых речь пойдет далее. Для краткости номер версии SCSI будем опускать, по умолчанию подразумевая Narrow SCSI-2. На ее примере разберем работу интерфейса, а особенности версии Wide отметим отдельно.

### 5.1. Физический интерфейс

Физически SCSI представляет собой шину, состоящую из 25 сигнальных цепей. Для защиты от помех каждая сигнальная цепь имеет свой отдельный обратный провод. На применяемых двухрядных разъемах контакты сигнальных и обратных цепей располагаются друг против друга. Это позволяет применять в качестве кабелей как витые пары проводов, так и плоские шлейфы, где сигнальные и обратные провода чередуются.

По типу сигналов различают линейные (Single Ended) и дифференциальные (Differential) версии SCSI. Их кабели и разъемы идентичны, но электрической совместимости устройств нет. Символические обозначения для разных версий приведены на рис. 5.5.



25 м (8 устройств) или 12 м (16 устройств).

**Рис. 5.5.** Универсальные символические обозначения версий SCSI **Дифференциальная** версия для каждой цепи задействует пару

проводников, по которым передается парафазный сигнал.

Эдесь используются специальные дифференциальные приемопередатчики, применяемые и в интерфейсе RS-485, что позволяет значительно увеличить длину кабеля, сохраняя частоту обмена (табл. 5.2). Дифференциальный интерфейс применяется в дисковых системах серверов. Традиционный дифференциальный интерфейс получил название «высоковольтный» — High Voltage Differential (HVD), поскольку в SCSI-3 ему появилась низковольтная альтернатива — Low Voltage Differential (LVD). Низковольтный вариант достигает

В широко используемой *линейной* версни каждый сигнал передается потенциалом с ТТЛ-уровнями относительно общего провода. Здесь общий (обратный) провод для каждого сигнала тоже должен быть отдельным. В дальнейшем речь пойдет об этой версии.

частоты 40 MT/с в устройствах Ultra2 SCSI при длине шины

Новые устройства с интерфейсом LVD могут работать на шине вместе с устройствами с линейным интерфейсом — для этого их буферные схемы содержат автоматический определитель типа интерфейса. Однако совместимость относится только к LVD — традиционные устройства с HVD могут работать только с себе подобными.

ма, что позволяет соединить их в цепочку. Длина кабеля зависит от версии интерфейса и частоты (см. табл. 5.2). При подсчете суммарной длины кабеля следует учитывать возможность использования одного порта хост-адаптера одновременно для внешних и внутренних подключений и суммировать длины внутренних и внешних кабелей. Таблица 5.2. Максимальная дляна кабалей SCSI

**Fast** 

(10 MT/c)

Ultra

(20 MT/c)

Ultra 2

(40 MT/c)

Плоский кабель используется для соединения устройств, расположенных в одном корпусе. На нем может быть наколото несколько разъемов. При необходимости кабели могут сращиваться через специальные переходные разъемы. Кабели сращиваются только через концевые разъемы, Т-образные ответвления недопустимы. Круглый кабель, состоящий из витых пар, используется для соединения вне корпусов устройств. ПУ внешнего исполнения обычно имеют два разъе-

| (Single ended)                             |      |      |      |                                                 |
|--------------------------------------------|------|------|------|-------------------------------------------------|
| Дифференциальный<br>(HVD)                  | 25 м | 12 м | 6 м  | -                                               |
| Дифференциальный<br>низковольтный<br>(LVD) | 25 м | 25 м | 25 м | 25 м<br>(8 устройств)<br>12 м<br>(16 устройств) |

#### А-кабель: стандартный для 8-битного интерфейса, 25 пар

Обычный

(5 MT/c)

Тил интерфейса

кий шлейф с разъемами IDC-50, для внешних — экранированный круглый кабель с разъемами CENTRONICS-50.

проводов. Для внутренних устройств используется плос-

- В-кабель: малораспространенный 16/32-битный расшири
  - тель SCSI-2. Р-кабель: 8/16-битный кабель с 34 парами проводов,

снабжен улучшенными миниатюрными экранированными разъемами. Применяется в интерфейсах SCSI-2/3, в 8-битном варианте контакты 1-5, 31-39, 65-68 не исполь-

зуются. Разъемы для внешнего подключения выглядят как

- миниатюрный вариант Centronics с плоскими контактами, внутренние имеют штырьковые контакты.
- Q-кабель: 68-проводное расширение до 32 бит, используется в паре с Р-кабелем и имеет аналогичную конструкцию.
- Жабель с разъемами DB−25P 8-битный, стандартный для Macintosh (см. табл. 5.5), используется на некоторых внешних устройствах (Iomega ZIP Drive). Встречается иная раскладка цепей, если 25-контактный разъем уста-

Назначение контактов разъемов кабелей приведено в табл. 5.3-5.6. Неудобство вызывает система нумерации контактов, которая различна для внешних и внутренних разъемов. Однако физическая раскладка проводов на разъеме и в

Возможны также различные варианты кабелей-переходников.

## плоском кабеле одинакова. Табына 5.2 Роззии Асабен 9031

новлен на хост-адаптере.

| Контакт разъема |          | Сигнал   | Контакт р   | Сигнал   |          |
|-----------------|----------|----------|-------------|----------|----------|
| Внутреннего     | Внешнего | ]        | Внутреннего | Внешнего | <u> </u> |
| 1               | 1        | GND      | 2           | 26       | DB0#     |
| 3               | 2        | GND      | 4           | 27       | DB1#     |
| 5               | 3        | GND      | 6           | 28       | DB2#     |
| 7               | 4        | GND      | 8           | 29       | DB3#     |
| 9               | 5        | GND      | 10          | 30       | DB4#     |
| 11              | 6        | GND      | 12          | 31       | DB5#     |
| 13              | 7        | GND      | 14          | 32       | DB6#     |
| 15              | 8        | GND      | 16          | 33       | DB7#     |
| 17              | 9        | GND      | 18          | 34       | DBP0#    |
| 19              | 10       | GND      | 20          | 35       | GND      |
| 21              | 11       | GND      | 22          | 36       | GND      |
| 23              | 12       | Reserved | 24          | 37       | Reserved |
| 25              | 13       | Open     | 26          | 38       | TERMPWR  |
| 27              | 14       | Reserved | 28          | 39       | Reserved |

Таблица 5.3 (продолжение)

27

14

GND

28

48

DB16#

| Контакт разъема           |                       | Сигнал Ко                              |        | Контакт р                        | онтакт разъема |                                  |     | Сигнал                                    |  |
|---------------------------|-----------------------|----------------------------------------|--------|----------------------------------|----------------|----------------------------------|-----|-------------------------------------------|--|
| Внутреннего               | Внешнего              |                                        | Вн     | утреннего                        | Bı             | нешнего                          | 5   |                                           |  |
| 29                        | 15                    | GND                                    | 30     |                                  | 40             |                                  | G   | ND                                        |  |
| 31                        | 16                    | GND                                    | 3      | 2                                | 4              | 1                                | A   | TN#                                       |  |
| 33                        | 17                    | GND                                    | 3,     | 4                                | 4              | 2                                | G   | ND                                        |  |
| 35                        | 18                    | GND                                    | 30     | 6                                | 4              | 3                                | В   | SY#                                       |  |
| 37                        | 19                    | GND                                    | 38     | 3                                | 4              | 4                                | A   | CK#                                       |  |
| 39                        | 20                    | GND                                    | 40     | )                                | 4              | 5                                | R   | ST#                                       |  |
| 41                        | 21                    | GND                                    | 4      | 2                                | 4              | 6                                | М   | SG#                                       |  |
| 43                        | 22                    | GND                                    | 4      | 1                                | 4              | 7                                | SI  | EL#                                       |  |
| 45                        | 23                    | GND                                    | 4      | 6                                | 4              | 8                                | C,  | /D#                                       |  |
| 47                        | 24                    | GND                                    | 48     | 3                                | 4              | 9                                | R   | EQ#                                       |  |
| 49                        | 25                    | GND                                    | 50     | )                                | 5              | 0                                | 1/1 | 0#                                        |  |
| Таблица 5.                | 4. Разъечы і          | 9-кабаля S                             | CSI    |                                  |                |                                  |     |                                           |  |
| Контакт                   | разъема               | Сигнал                                 | 7      | Контак                           | T D            | азъема                           |     | Сигнал                                    |  |
| Внугреннего               | <u>'</u>              |                                        | ŀ      | Внутреннег                       | ÷              |                                  | 0   |                                           |  |
| 1                         | 1                     | GND                                    | 7      | 2                                |                | 35                               |     | GND                                       |  |
| 3                         | 2                     | GND                                    | 1      | 4                                |                | 36                               |     | DB8#                                      |  |
| 5                         | 3                     | GND                                    | 1      | 6                                |                | 37                               |     | DB9#                                      |  |
|                           |                       |                                        |        |                                  |                |                                  |     |                                           |  |
| 7                         | 4                     | GND                                    | $\neg$ | 8                                |                | 38                               |     | DB10#                                     |  |
| 9                         | 4<br>5                | GND<br>GND                             | 1      | 8                                |                | 38<br>39                         |     | DB10#<br>DB11#                            |  |
|                           |                       |                                        |        |                                  |                |                                  |     |                                           |  |
| 9                         | 5                     | GND                                    |        | 10                               |                | 39                               |     | DB11#                                     |  |
| 9                         | 5                     | GND<br>GND                             |        | 10<br>12                         |                | 39<br>40                         |     | DB11#<br>DB12#                            |  |
| 9<br>11<br>13             | 5<br>6<br>7           | GND<br>GND<br>GND                      |        | 10<br>12<br>14                   |                | 39<br>40<br>41                   |     | DB11#<br>DB12#<br>DB13#                   |  |
| 9<br>11<br>13<br>15       | 5<br>6<br>7<br>8      | GND<br>GND<br>GND<br>GND               |        | 10<br>12<br>14<br>16             |                | 39<br>40<br>41<br>42             |     | DB11#<br>DB12#<br>DB13#<br>DB14#          |  |
| 9<br>11<br>13<br>15<br>17 | 5<br>6<br>7<br>8<br>9 | GND<br>GND<br>GND<br>GND<br>GND        |        | 10<br>12<br>14<br>16<br>18       |                | 39<br>40<br>41<br>42<br>43       |     | DB11#<br>DB12#<br>DB13#<br>DB14#<br>DB15# |  |
| 9<br>11<br>13<br>15<br>17 | 5<br>6<br>7<br>8<br>9 | GND<br>GND<br>GND<br>GND<br>GND<br>GND |        | 10<br>12<br>14<br>16<br>18<br>20 |                | 39<br>40<br>41<br>42<br>43<br>44 |     | DB11# DB12# DB13# DB14# DB15# DBP1#       |  |

| Контакт разъема |             | Сигнал  |    | Контакт разъема |    |            | Сигнал |         |
|-----------------|-------------|---------|----|-----------------|----|------------|--------|---------|
| Внутреннего     | Внешнего    |         |    | Внутренне       | го | Внешне     | го     | ]       |
| 29              | 15          | GND     |    | 30              |    | 49         |        | DB17#   |
| 31              | 16          | GND     |    | 32              |    | 50         |        | DB18#   |
| 33              | 17          | TERMPW  | 'R | 34              |    | 51         |        | TERMPWR |
| 35              | 18          | TERMPW  | 'n | 36              |    | 52         |        | TERMPWR |
| 37              | 19          | GND     |    | 38              |    | 53         |        | DB19#   |
| 39              | 20          | GND     |    | 40              |    | 54         |        | DB20#   |
| 41              | 21          | GND     |    | 42              |    | 55         |        | DB21#   |
| 43              | 22          | GND     |    | 44              |    | 56         |        | DB22#   |
| 45              | 23          | GND     |    | 46              |    | 5 <b>7</b> |        | DB23#   |
| 47              | 24          | GND     |    | 48              |    | 58         |        | DBP2#   |
| 49              | <b>2</b> 5  | GND     |    | 50              |    | 59         |        | DB24#   |
| 51              | 26          | GND     |    | 52              |    | 60         |        | DB25#   |
| 53              | 27          | GND     |    | 54              |    | 61         |        | DB26#   |
| 55              | 28          | GND     |    | 56              |    | 62         |        | DB27#   |
| 5 <b>7</b>      | 29          | GND     |    | 58              |    | 63         |        | DB28#   |
| 59              | 30          | GND     |    | 60              |    | 64         |        | DB29#   |
| 61              | 31          | GND     |    | 62              |    | <b>6</b> 5 |        | DB30#   |
| 53              | 32          | GND     |    | 64              |    | 66         |        | DB31#   |
| <b>6</b> 5      | 33          | GND     |    | 66              |    | 67         |        | DBP2#   |
| 67              | 34          | GND     |    | 68              |    | 68         |        | GND     |
| Таблица 5.5.    | Passeu SCSI | DB-25   |    |                 |    |            |        |         |
| Контакт         | Сигнал      | Контакт | C  | Сигнал          | К  | онтакт     | Cı     | игнал   |
| 1               | REQ#        | 10      | [  | DB3#            | 1  | 9          | s      | EL#     |
| 2               | MSG#        | 11      | C  | DB5#            | 2  | 0          | D      | BP0#    |
| 3               | I/O#        | 12      |    | DB6#            | 2  | 1          | D      | B1#     |
| 4               | RST#        | 13      | С  | DB7#            | 2  | 2          | D      | B2#     |
| 5               | ACK#        | 14      | C  | SND             | 2  | 3          | D      | B4#     |
| 6               | BSY#        | 15      | C  | C/D#            | 2  | 4          | G      | ND      |
| 7               | GND         | 16      | G  | ND I            | 2  | 5          | T      | ERMPWR  |
| 8               | DB0#        | 17      | Α  | TN#             |    |            |        |         |
| 9               | GND         | 18      | G  | AND             |    |            |        |         |

Таблица 5.6, Разъемы Р-, Q-кабелей SCSI

GND

29

63

REQ#

REQQ#

| Контакт | Р- и Q-кабели,<br>сигнал | Контакт | Р-кабель,<br>сигнал | Q-кабель,<br>сигнал |
|---------|--------------------------|---------|---------------------|---------------------|
| 1       | GND                      | 35      | DB12#               | DB28#               |
| 2       | GND                      | 36      | DB13#               | DB29#               |
| 3       | GND                      | 37      | DB14#               | DB30#               |
| 4       | GND                      | 38      | DB15#               | DB31#               |
| 5       | GND                      | 39      | DBP1#               | DBP3#               |
| 6       | GND                      | 40      | DB0#                | DB16#               |
| 7       | GND                      | 41      | DB1#                | DB17#               |
| 8       | GND                      | 42      | DB2#                | DB18#               |
| 9       | GND                      | 43      | DB3#                | DB 19#              |
| 10      | GND                      | 44      | DB4#                | DB20#               |
| 11      | GND                      | 45      | DB5#                | DB21#               |
| 12      | GND                      | 46      | DB6#                | DB22#               |
| 13      | GND                      | 47      | DB7#                | DB23#               |
| 14      | GND                      | 48      | DBP0#               | DBP2#               |
| 15      | GND                      | 49      | GND                 | GND                 |
| 16      | GND                      | 50      | GND                 | GND                 |
| 17      | TERMPWR                  | 51      | TERMPWR             | TERMPWRQ            |
| 18      | TERMPWR                  | 52      | TERMPWR             | TERMPWRQ            |
| 19      | Reserved                 | 53      | Reserved            | Reserved            |
| 20      | GND                      | 54      | GND                 | GND                 |
| 21      | GND                      | 55      | ATN#                | Terminated          |
| 22      | GND                      | 56      | GND                 | GND                 |
| 23      | GND                      | 57      | BSY#                | Terminated          |
| 24      | GND                      | 58      | ACK#                | ACKQ#               |
| 25      | GND                      | 59      | RST#                | Terminated          |
| 26      | GND                      | 60      | MSG#                | Terminated          |
| 27      | GND                      | 61      | SEL#                | Terminated          |
| 28      | GND                      | 62      | C#/D                | Terminated          |

| ных шлейфов обязательно устанавливаются терминаторы,                                                                                  |
|---------------------------------------------------------------------------------------------------------------------------------------|
| согласованные по импедансу с кабелем. Они предназначены                                                                               |
| для «подтягивания» уровня сигналов линий к высокому по-                                                                               |
| тенциалу. Терминаторы служат и для предотвращения отра-                                                                               |
| жения сигналов от концов кабеля. По исполнению термина-                                                                               |
| торы могут быть внутренние (размещенные на печатной плате                                                                             |
| устройства) и внешние (устанавливаемые на разъемы кабеля                                                                              |
| или устройства). По электрическим свойствам различают                                                                                 |
| следующие типы терминаторов:                                                                                                          |
| Пассивные (SCSI-1) с импедансом 132 Ом, представляющие собой обычные резисторы. Не пригодны для режимов SCSI-2 с частотой выше 5 МГц. |
| ** <i>Активные</i> с импедансом 110 Ом — специальные терминаторы для работы на частоте 10 МГц.                                        |
| ₱ FPT (Forced Perfect Terminator) — улучшенный вариант активных терминаторов с ограничителями выбросов.                               |
| Активные терминаторы требуют питания, для чего в интер-                                                                               |

фейсе имеются специальные линии TERMPWR. Питание по-

Select — выбор ЦУ инициатором (Select) или

Р- и О-кабели.

сигнал

GND

GND

GND

GND

GND

ступает от ИУ.

Сигнал

BSY#

SEL#

Таблица 5.7. Назначение сигналов шины SCSI

Назначение

*Визу* — шина занята

инициатора ЦУ (Reselect)

Контакт

30

31

32

33

34

Контакт

64

65

66

67

68

Р-кабель.

сигнал

1/0#

**DB8#** 

DB9#

DB10#

**DB11#** 

Назначение сигналов раскрывает табл. 5.7. Все сигналы шины являются *L-активными*: активному состоянию и логической единице соответствует низкий потенциал. На концах кабель-

О-кабель.

Terminated

сигнал

DB24#

DB25#

DB26#

DB27#

|        | *****     |        |        | 888  |
|--------|-----------|--------|--------|------|
| T(x)   | 12.5      | 205    | 0)     | 88   |
| æ 2000 | مغضف      | de in  | es a   |      |
| vene   | * 2000000 | 000000 | 390000 | 9000 |
|        |           |        |        |      |

| Таблица 5.7 (продолжение) |                                                                                                                                                                                                                    |  |  |  |  |
|---------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Сигнал                    | Назначение                                                                                                                                                                                                         |  |  |  |  |
| C/D#                      | Control/Data — управление (низкий<br>уровень)/данные (высокий уровень)                                                                                                                                             |  |  |  |  |
| I/O#                      | Input/Output — направление передачи относительно ИУ: вводу в ИУ соответствует низкий уровень. Используется для различия прямой (Select) и обратной (Reselect) выборки: фазе Selection соответствует пизкий уровень |  |  |  |  |
| MSG#                      | Message — передача сообщения                                                                                                                                                                                       |  |  |  |  |
| DB[0:31]#                 | Data Bus — инверсная шина данных                                                                                                                                                                                   |  |  |  |  |
| DP[0:3]#                  | Data Parity — инверсные биты паритета, дополняют количество единичных бит байта до нечетного. DPO# относится к DB[0:7], DP3# — к DB[24:31]. В фазе арбитража не действуют                                          |  |  |  |  |
| TERMPWR                   | Terminator Power — питание терминаторов                                                                                                                                                                            |  |  |  |  |
| ATN#                      | Attention — внимание                                                                                                                                                                                               |  |  |  |  |
| REQ#                      | Request — запрос от ЦУ на пересылку данных                                                                                                                                                                         |  |  |  |  |
| ACK#                      | Acknowledge — подтверждение передачи (ответ на REQ#)                                                                                                                                                               |  |  |  |  |
| RST#                      | Reset — сброс                                                                                                                                                                                                      |  |  |  |  |

Каждое устройство SCSI, подключенное к шине, должно иметь свой уникальный адрес, назначаемый при конфигу-

рировании. Для 8-битной шины диапазон значений адреса  $\hat{0}-\hat{7}$ , для 16-битной — 0–15. Адрес задается предварительной

установкой переключателей или джамперов. Для хост-адаптера возможно программное конфигурирование. Адресация устройств на шине в фазах выборки осуществляется через идентификатор SCSI ID, представляющий адрес в позиционном коде. Адрес определяет номер линии шины данных, которой осуществляется выборка данного устройства. Уст-

ройство с нулевым адресом выбирается низким уровнем на линии DB0# (SCSI ID=00000001), с адресом 7 — на линии DB7# (SCSI ID=10000000). Для ИУ значение идентифика-

тора определяет приоритет устройства при использовании шины, наибольший приоритет имеет устройство с большим значением адреса. Адрес и идентификатор — всего лишь две различные формы представления одного и того же параметра.

ИУ, а ЦУ ее исполняет. ИУ выбирает ЦУ по его идентификатору. Чаще всего роли устройств фиксированы: хост-адаптер является инициатором (ИУ), а ПУ — целевым (ЦУ). Возможны комбинированные устройства, выступающие в роли и ИУ, и ЦУ. В ряде случаев роли устройств меняются: ЦУ может, пройдя фазу арбитража, выполнить обратную

выборку (Reselect) ИУ для продолжения прерванной операции, При выполнении команды копирования (Copy) ИУ дает

В любой момент обмен информацией по шине может происходить только между парой устройств. Операцию начинает

указание ведущему устройству копирования (Copy Master) на обмен данными, который может производиться и с другим ЦУ (для которых ведущее устройство копирования выступит в роли ИУ).

Информация по шине данных передается побайтно асинх-

ронно, используя механизмы запросов (REQuest) и подтверждений (ACKnowledge). Каждый байт контролируется на нечетность (кроме фазы арбитража), но контроль может быть отключен. Интерфейс имеет возможность синхронной передачи данных, ускоряющей обмен.

## 5.2. Фазы шины

Шина может находиться в одной из перечисленных фаз. Роли источников сигналов между ИУ и ЦУ описаны в табл. 5.8.

#### источников сигналов между

Таблица, 5.8. Источники сигналов SCSI

| Фаза        | Сигнал |      |                                 |               |                |  |  |  |
|-------------|--------|------|---------------------------------|---------------|----------------|--|--|--|
| шины        | BSY#   | SEL# | REQ#,<br>C/D#,<br>I/O#,<br>MSG# | ACK#,<br>ATN# | DBx#,<br>DBPx# |  |  |  |
| Bus Free    | -      | T-   | <u> </u>                        | T -           | T              |  |  |  |
| Arbitration | AA     | WA   | ] -                             | -             | SID            |  |  |  |
| Selection   | I, T   | I    | -                               | I             | I              |  |  |  |
| Reselection | I, T   | T    | Т                               | I             | Т              |  |  |  |
| Command     | Т      |      | T                               | I             | I              |  |  |  |

#### Таблица 5.8 (продолжение)

| Фаза        | Сигнал |          |                                 |               |                |  |  |
|-------------|--------|----------|---------------------------------|---------------|----------------|--|--|
| шины        | BSY#   | SEL#     | REQ#,<br>C/D#,<br>I/O#,<br>MSG# | ACK#,<br>ATN# | DBx#,<br>DBPx# |  |  |
| Data IN     | Т      | -        | T                               | I             | Т              |  |  |
| Data OUT    | Т      | <b>-</b> | Т                               | 1             | I              |  |  |
| Status      | Т      | -        | T                               | 1             | T              |  |  |
| Message IN  | Т      | T-       | Т                               | 1             | Т              |  |  |
| Message OUT | T      | -        | T                               | I             | I              |  |  |

I — источник сигнала — ИУ;

Т – источник сигнала – ЦУ;

фазу Selection или Reselection.

АА — источник сигнала — устройство, активное в арбитраже;

WA — источник сигнала — устройство-победитель в арбитраже;

SID — каждое устройство управляет только битом данных, соответствующим значению его SCSI ID.

В фазе *Bus Free* шина находится в состоянии покоя — нет никаких процессов обмена; она готова к арбитражу. Признаком является пассивное состояние линий BSY# и SEL#.

В фазе Arbitration устройство может получить право на управление шиной. Дождавшись покоя шины (Bus Free), устройство вводит сигнал BSY# и свой идентификатор SCSI ID. Если идентификаторы выставили несколько устройств одновременно, то право на управление шиной получает устройство с наибольшим адресом, а остальные устройства отключаются до следующего освобождения шины. Устройство, выигравшее арбитраж, вводит сигнал SEL# и переходит в

В фазе Selection ИУ, выигравшее арбитраж, вводит на шину данных результат логической функции ИЛИ от пары идентификаторов — своего и ЦУ, — сопровождая его битом паритета. Установкой сигнала ATN# ИУ указывает, что следующей фазой будет Message OUT. ИУ снимает сигнал BSY#.

Отсутствие сигнала I/O# отличает данную фазу от *Reselection*. Адресованное ЦУ отвечает сигналом BSY#, если паритет коршину или вводит сигнал сброса RST#. Фаза Reselection аналогична предыдущей, но ее вводит ЦУ. Фаза появляется в том случае, когда ЦУ на время исполнения команды отключалось от шины. По завершении внутренней операции это устройство, выиграв арбитраж, будет вызывать ИУ, которое ранее породило исполнение операции.

ректный и на шине данных присутствует только пара идентификаторов (его и ИУ). На некорректные значения данных устройства отвечать не должны. Если за заданное время ЦУ не ответило, срабатывает тайм-аут, ИУ освобождает

ЦУ снимает сигнал BSY#, активность сигнала I/O# отличает данную фазу от фазы Selection. Адресованное ИУ отвечает сигналом BSY#, условия ответа и тайм-аут аналогичны предыдущей фазе.

В фазах Command, Data, Status и Message по шине данных передается информация, фазы идентифицируются сигнала-

ми MSG#, C/D# и I/O# (табл. 5.9), которыми управляет ЦУ. ИУ может потребовать посылки сообщения (фаза Message OUT) введением сигнала ATN#, а ЦУ может освободить шину, сняв сигналы MSG#, C/D#, I/O# и BSY#. Теблица, 5.9. Информационные meau SCS

|      | Сигнал |      | Фаза     | Направление |
|------|--------|------|----------|-------------|
| MSG# | C/D#   | I/O# | 1        |             |
| 0    | 0      | 0    | Data OUT | I⇒T         |
| 0    | 0      | 1    | Data IN  | I⇔T         |
| ^    |        |      | C 1      | T . T       |

| 0 | 0 | 0 | Data OUT        | I⇔T |
|---|---|---|-----------------|-----|
| 0 | 0 | 1 | Data IN         | I⇔T |
| 0 | 1 | 0 | Command         | I⇒T |
| 0 | 1 | 1 | Status          | I⇔T |
| 1 | 0 | 0 | Зарезервировано |     |
| 1 | 0 | 1 | Зарезервировано |     |
| 1 | 1 | 0 | Message OUT     | I⇒T |
| 1 | 1 | 1 | Message IN      | I⇔T |

Временные диаграммы асинхронного обмена приведены на рис. 5.6. Здесь передача каждого байта сопровождается взаимосвязанной парой сигналов REQ#/ACK#. ИУ фиксирует

принимаемые данные, получив сигнал REQ# (по отрицатель-

ному перепаду). ЦУ считает принимаемые данные действительными по отрицательному перепаду сигнала АСК#. Асинхронный обмен поддерживается всеми устройствами для всех фаз передачи информации.



**Рис. 5.6.** Временные диаграммы асинхронного обмена (DI — данные от ИУ, DT — данные от ЦУ)

Фазы передачи данных Data OUT и Data IN по предваритель-

ной «договоренности» устройств могут выполняться и в синхронном режиме обмена, диаграммы которого приведены на рис. 5.7. При согласовании синхронного режима определяются минимальные длительности и периоды управляющих импульсов ACK# и REQ#, а также допустимое отставание подтверждений от запросов (REO/ACK offset agreement). ЦУ передает серию данных, сопровождаемых стробами REQ# (рис. 5.7а) в темпе, ограниченном установленными временными параметрами. ИУ фиксирует принимаемые данные по отрицательному перепаду сигнала REQ#, но отвечать на них сигналом АСК# может с некоторым опозданием. Как только отставание числа принятых сигналов АСК# от числа посланных REQ# достигнет оговоренного предельного значения (в данном примере 2), ЦУ приостановит обмен до прихода очередного подтверждения АСК#. Операция будет считаться завершенной, когда число принятых подтверждений совпадет с числом посланных запросов. При приеме данных ЦУ механизм согласования остается тем же, но данные фиксируются

В спецификации SCSI-1 момент возобновления передачи по устранении отставания описан нечетко, в результате чего разработчики могли считать, что очередной запрос (и данные) может последовать лишь после окончания (положительного перепада) сигнала АСК#. Устройство, на это рассчитанное, может терять данные: для него последний сигнал REQ# (и данные) будет неожиданным и выглядеть как

по отрицательному перепаду сигнала АСК# (рис. 5.76).

превышение согласованного смещения.



!/O#

Фазы Message IN и Message OUT служат для передачи сообщений. Фазу Message OUT ЦУ вводит в ответ на условие Attention, порождаемое ИУ сигналом ATN#, когда оно нуждается в посылке сообщения ЦУ. Фазу Message IN ЦУ вволит при необходимости посылки сообщения ИУ. Между фазами передачи информации сигналы BSY#, SEL#, REQ# и ACK# должны оставаться в неизменном состоянии, меняться могут только значения сигналов C/D#, I/O#, MSG# и шины ланных. Сигналы ATN# и RST# могут порождать условия Attention и Reset соответственно, причем асинхронно по отношению к фазам шины. Эти условия могут привести к изменению пред-

просы на передачу данных к ИУ и от него соответственно.

определенного порядка фаз. Сигнал ATN# вводится ИУ во шины. Сигнал RST# вводится в любой момент любым устройством, и по условию Reset все устройства должны немедленно освободить шину. В зависимости от настройки, принятой для всех устройств конкретной системы, возможно выполнение одного из двух вариантов сброса. «Жесткий» сброс переводит устройства в состояние, принятое по включению питания, сбрасывая все текущие процессы, очереди и т. п. В случае «мягкого» сброса после освобождения шины устройства пытаются завершить начатые операции, сохраняя текущие назначения настроек.

время любой фазы, кроме арбитража и состояния покоя Каждый процесс ввода/вывода состоит из следующей последовательности фаз шины: из состояния Bus Free через фазу Arbitration переход к фазе Selection или Reselection. Далее следуют фазы передачи информации (Command, Data, Status, Message). Завершающей фазой является Message In, в которой передается сообщение Disconnect или Command Complete, после чего шина переходит в состояние покоя Bus Free.

Архитектура SCSI обеспечивает для каждого процесса ввода/вывода сохранение набора из трех указателей — Saved

SCSI Pointers, для команды, состояния и данных. ИУ имеет текущий набор указателей (только один), в который копируется сохраненный набор для текущего процесса. Текущие указатели указывают на очередной байт команды, состоягда указывают на начала блоков дескрипторов команд и состояния. Сохраненный указатель данных указывает на начало блока данных до тех пор, пока ПУ не пришлет сообщение Save Data Pointer. По его приему будет сохранен текущий указатель данных. Когда ЦУ отключается от шины, информация о текущем процессе ввода/вывода содержится в сохраненном наборе указателей. При возобновлении пропесса ЦУ сообщением Restore Pointers может потребовать у

ния и данных, которые будут передаваться между памятью ИУ и ЦУ. Сохраненные указатели команды и состояния все-

жить выполнение команд данного процесса ввода/вывода. Поскольку указатвль данных может быть модифицирован ЦУ до завершения ввода/ вывода, использование указатвля для определения реального количества переданных данных дает ненадежные результаты.

ИУ скопировать сохраненный набор в текущий и продод-

# 5.3. Управление интерфейсом

Для управления интерфейсом служит система сообщений Message System, которыми обмениваются ИУ и ЦУ. Обмен

происходит в фазах Message IN/OUT (см. выше), в одной фазе может передаваться несколько сообщений. Одно сообщение не может расшепляться на несколько фаз. Форматы сообщений стандартизованы; каждое сообщение начинается с кода. Существуют однобайтные (коды 00h, 02h-1Fh, 80h-FFh),

двухбайтные (коды 20h-2Fh) и расширенные сообщения (код 01h). В двухбайтном сообщении второй байт является аргументом сообщения. В расширенных сообщениях второй байт задает длину, а последующие байты несут код и аргументы сообщения. Коды сообщений приведены в табл. 5.10.

| Код | Направление | Сообщение            | Назначение                                                                       |
|-----|-------------|----------------------|----------------------------------------------------------------------------------|
| 00h | In          | Command<br>Complete  | Процесс ввода/вывода завершен, информация о состоянии послана в сообщении Status |
| 02h | In          | Save Data<br>Pointer | Сохранение указателя данных                                                      |

| *************************************** | .10 (продолжение) | Сообщение                                    | Назначение                                                                                                                               |
|-----------------------------------------|-------------------|----------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------|
| Код                                     | Направление       | <del></del>                                  |                                                                                                                                          |
| 03h                                     | In                | Restore Pointers                             | Восстановление<br>указателей                                                                                                             |
| 04h                                     | In                | Disconnect                                   | Текущее соединение разрывается, но для продолжения процесса потребуется повторное соединение (не вызывает сохранения текущих указателей) |
| 04h                                     | Out               | Disconnect                                   | Инструкция ЦУ<br>на разрыв соединения                                                                                                    |
| 05h                                     | Out               | Initiator<br>Detected Error                  | ИУ обнаружило ошибку<br>на шине                                                                                                          |
| <b>0</b> 6h                             | Out               | Abort                                        | Сброс всех процессов,<br>связанных с данной<br>парой I_T, и<br>освобождение шины                                                         |
| <b>07</b> h                             | In/Out            | Message Reject                               | Сообщение (или его параметры) недействительны для получателя                                                                             |
| <b>0</b> 8h                             | Out               | No Operation                                 | ИУ нечего ответить на запрос сообщения                                                                                                   |
| 09h                                     | Out               | Message Parity<br>Error                      | Последний байт сообщения принят наверным паритетом                                                                                       |
| 0Ah                                     | In                | Linked<br>Command<br>Complete                | Цепочка команд завершена. ИУ может инициализировать указатели для новой цепочки                                                          |
| 0Bh                                     | In                | Linked<br>Command<br>Complete (With<br>Flag) | То же, но ИУ между цепочками команд вызывает прерывание в хост-системе                                                                   |
| 0Ch                                     | Out               | Bus Device<br>Reset                          | Аппаратный сброс ЦУ и освобождение шины                                                                                                  |
| 0Dh                                     | Out               | Abort Tag                                    | Сброс текущего процесса, связанного с данной парой I_T, и освобождение шины                                                              |

| Код                     | Направление | Сообщение                | Назначение                                                                                                         |
|-------------------------|-------------|--------------------------|--------------------------------------------------------------------------------------------------------------------|
| 0Eh                     | Out         | Clear Queue              | Сброс всех процессов и освобождение шины (эквивалентно серии сообщений Abort, принятых от всех ИУ)                 |
| 0Fh                     | In/Out      | Initiate<br>Recovery     | Сообщение<br>для уведомления<br>об асинхронных событиях<br>(ЦУ временно<br>становится ИУ)                          |
| 10h                     | Out         | Release<br>Recovery      | Завершение обработки асинхронных событий                                                                           |
| 11h                     | Out         | Terminate I/O<br>Process | Принудительное завершение текущего процесса без логического повреждения носителя у ЦУ                              |
| 12h — 1Fh,<br>30h — 7Fh | Зарезе      | рвированы для 1          | -байтных сообщений                                                                                                 |
| 80h -FFh                | Out         | Identify                 | Установление связи типа<br>I_T_L или I_T_R                                                                         |
| 80h -FFh                | In          | Identif y                | Восстановление связи типа I_Т_L или I_Т_R при повторном соединении. Вызывает восстановление сохраненных указателей |
|                         | 2-          | -байтные сообще          |                                                                                                                    |
| 20h                     | In          | Simple Queue<br>Tag      | Процесс помещен<br>в очередь, аргумент — тег<br>(00h-FFh)                                                          |
| 20h                     | Out         | Simple Queue<br>Tag      | Обращение к конкретному процессу маркированной очереди, аргумент — тег (00h—FFh)                                   |
| 21h                     | Out         | Head Of Queue<br>Tag     | Помещение процесса<br>в начало маркированной<br>очереди для данного LUN,<br>аргумент — тег (00h-FFh)               |
| 22h                     | Out         | Ordered Queue<br>Tag     | Помещение процесса<br>в конец маркированной<br>очереди для данного LUN,<br>аргумент — тег (00h-FFh)                |

# Таблица 5.10 (продолжение)

02h

03h

00h, 04h - FFh

| Код                    | Hanpai | зление                                             | Сообщение                                | Назначение                                                                                                           |  |
|------------------------|--------|----------------------------------------------------|------------------------------------------|----------------------------------------------------------------------------------------------------------------------|--|
| 23h                    | In     |                                                    | Ignore Wide<br>Residue                   | Последние байты последнего переданного слова недействительны (аргумент см. в табл. 5.11)                             |  |
| 24h-2Fh                | Зарез  | ервиро                                             | ваны для 2-байт                          | ных сообщений                                                                                                        |  |
|                        |        |                                                    | . Первый байт<br>орым — расшир           | – 01h, в поле «код» первым<br>енный код                                                                              |  |
| 05h, 00h               | In     |                                                    | Modify Data<br>Pointer                   | Запрос модификации указателя данных — суммирование текущего указателя с 4-байтным аргументом сообщения               |  |
| 03h, 01h               | In/Out |                                                    | Synchronous<br>Data Transf er<br>Request | Параметры синхронного режима обмена. 1-й байт аргумента определяет период посылки, 2-й — допустимое смещение REQ/ACK |  |
| 02h, 03h               | In/Out |                                                    | Wide Data<br>Transf er<br>Request        | Разрядность передач в фазах данных. Аргумент задает число байт: 0 — 1 байт, 1 — 2 байта, 2 — 4 байта                 |  |
| (аблица 5.11.          | Игнори | рование                                            | лишних данных                            | 100                                                                                                                  |  |
| Значение<br>2-го байта |        | Игнорировать биты данных<br>при разрядности обмена |                                          |                                                                                                                      |  |
|                        |        | 32 би                                              | T                                        | 16 бит                                                                                                               |  |
| 01h DB[3               |        | 1:24]                                              | DB[15:8]                                 |                                                                                                                      |  |

В SCSI-2 для установления связи процесса с конкретным логическим устройством I\_T\_L (Initiator\_Target\_LUN) или с конкретной целевой программой I\_T\_R (Initiator\_Target\_TRN),

Зарезервировано

Зарезервировано

Зарезервировано

DB[31:16]

DB[31:8]

Зарезервировано

только одному LUN или TRN. Если ЦУ во время выполнения процесса обнаружит сообщение с иным адресом связи, оно обязано освободить шину (ситуация неожиданного разрыва). Единичным значением бита 6 DiscPriv при передаче сообщения ИУ наделяет ЦУ правом разрыва соединения. ИУ может проинструктировать ЦУ на разрые соединения,

а также предоставления права разрыва соединения служат сообщения Identify. В байте их кодов биты [2:0] в зависимости от бита 5 LUNTAR задают номер LUN (LUNTAR=0) или TRN (LUNTAR=1). Каждый процесс может быть адресован

посылает одноименное сообщение (предварительно ЦУ может потребовать сохранения указателя данных, послав сообщение Save Data Pointer) и освобождает шину. Если ЦУ не поддерживает эту возможность, оно отвечает сообщением Message Reject. Когда процесс, продолжающийся в устройстве, потребует передачи данных, через фазу арбитража ЦУ

обратится к ИУ за продолжением обмена.

послав ему сообщение Disconnect. Получив сообщение, ЦУ

С помощью сообщений согласуются параметры синхронного режима и разрядность данных. Процесс согласования синхронного обмена называется Synchronous Negotiation. Устройство, запрашивающее синхронный обмен, посылает сообщение Synchronous Data Transfer Request с указанием допустимого периода цикла и отставания REQ/ACK. Если другой участник обмена поддерживает синхронный режим, он

предложит свои параметры. Согласованными параметрами будут максимальный период и минимальное отставание (нулевое отставание эквивалентно асинхронному режиму). Выб-

ранный режим будет относиться только к фазам передачи между данной парой устройств. Отвергнутое сообщение является требованием асинхронного режима. Поскольку старые хост-адаптеры не поддерживали согласование синхрон-

ного режима, на ЦУ запрос синхронного режима может быть заблокирован. О возможности работы в синхронном режиме хост может узнать, послав команды Request Sense и Inquiry.

Разрядность передач согласуется аналогично посредством сообщений Wide Data Transfer Request. Согласованные режи-

мы будут действовать до сброса устройств по сообщению Bus Device Reset или «жесткого» сброса, что приведет к уссование режимов не должно инициироваться в каждом процессе, поскольку затраты времени на эту процедуру сведут на нет выигрыш в производительности.

тановке предопределенных режимов по включению. Согла-

#### **5.4. Типы ПУ**

типных *периферийных устройств* (ПУ), перечень их стандартизованных типов приведен в табл. 5.12. Сложное ПУ может представляться несколькими ЛУ SCSI. По характеру обмена данных устройства разделяются на 2 класса — блочные (Block Device) с типами 0, 4, 5, 7 и поточные (Stream

Direct-access device — устройства прямого доступа

Кажлое ЛУ может представлять одно или несколько одно-

### Таблица 5.12. Типы ПУ SCSI

Код типа

0Dh-1Eh

1Fh

00h

Device) с типами 1, 2, 3, 9.

Назначение

Зарезервировано

| 0011        | (накопители на магнитных дисках)                                                                  |  |  |  |  |
|-------------|---------------------------------------------------------------------------------------------------|--|--|--|--|
| 01h         | Sequential-access device — устройства последовательного доступа (накопители на магнитных лентах)  |  |  |  |  |
| 02h         | Printer device — принтеры                                                                         |  |  |  |  |
| 03h         | Processor device — процессоры (устройства обработки данных)                                       |  |  |  |  |
| 04h         | Write-once device — устройства однократной записи (некоторые оптические диски)                    |  |  |  |  |
| <b>0</b> 5h | CD-ROM device — приводы CD-ROM                                                                    |  |  |  |  |
| 06h         | Scanner device — сканеры                                                                          |  |  |  |  |
| <b>07</b> h | Optical memory device — устройства оптической память                                              |  |  |  |  |
| 08h         | Medium Changer device — устройства смены носителей (jukebox)                                      |  |  |  |  |
| 09h         | Communications device — коммуникационные устройства                                               |  |  |  |  |
| 0Ah-0Bh     | Устройства класса ASC IT8 (Graphic Arts Pre-Press Devices — высококачественные устройства печати) |  |  |  |  |
| 0Ch         | Array controller device — контроллеры массивов накопителей                                        |  |  |  |  |
|             |                                                                                                   |  |  |  |  |

Неизвестный тип или устройство отсутствует

ления чтением и записью, а также обеспечения надежности хранения данных (ЕСС или СКС-коды). Формат дополнительных данных не регламентируется, ЦУ скрывает эти данные от ИУ.

Для каждого блока может быть установлена своя длина, но чаще используют единую длину блока для всего носителя. Группа смежных блоков одинаковой длины называется экстентом (extent), экстенты определяются командой МОDE SELECT, длину блока можно узнать по команде МОDE SENSE.

После изменения длины блока для активизации экстента

Носитель может быть разделен на области, одна из которых используется для хранения блоков данных, другая резервируется для замены дефектных блоков, часть носителя может использоваться контроллером для обслуживания устройства. Дефектные блоки области данных могут быть переназначены на другую область носителя, что позволяет их скрыть.

обычно требуется форматирование.

тожет

Носитель

Устройства прямого доступа (0) позволяют сохранять блоки данных. Каждый блок хранится по уникальному логическому адресу LBA — Logical Block Address. Взаимное расположение логических блоков на носителе не регламентируется. Адрес первого логического блока — нулевой, последнего — (n-1), где п — общее число блоков. В цепочках команд устройствами может поддерживаться относительная адресация, когда исполнительный адрес в команде определяется смещением относительно адреса, действовавшего в предыдущей команде. Блоки данных хранятся на носителе вместе с дополнительной информацией, используемой контроллером для управность по учетов предыдущей команде.

быть смонтирован. Устройство может быть зарезервировано ИУ, при этом доступ к нему других ИУ ограничивается. Ограничения распространяются на ЛУ или экстент.

(Removable). Сменяемый носитель в картридже (или чехле) называют томом (Volume). Для чтения/записи том должен

быть фиксированным и сменяемым

Устройства, имеющие кэш данных, могут поддерживать политику обратной записи (Write Back). При этом появляют-

ле записи в кэш, а не на носитель. Сообщения об ошибках при WB поступают к ИУ с опозданием. Чтобы избежать этих неудобств, ИУ может запретить устройству использовать WB. Отдельные блоки в кэше можно фиксировать, не допуская их замещения при последующих операциях обмена. Типичный пример устройств прямого доступа — накопитель на магнитном диске. Есть устройства прямого доступа на ленточном носителе — Floppy Tape. Именно для них эффективна команда SEEK. Устройства прямого доступа могут не иметь подвижных носителей, а быть основаны на памяти разной природы: SRAM, DRAM, FRAM, EEPROM, флэш-память. Устройства последовательного доступа (1) имеют ряд особенностей, связанных с принципом их действия. Носитель представляет собой магнитную ленту с многодорожечным, серпантинным или наклонно-строчным типом записи. Носитель всегда сменяемый, с некоторым конструктивным обрамлением (катушка, картридж) — также называется томом. Том име-

ся интервалы времени, в течение которых внезапное отключение питания устройства приведет к потере данных, поскольку сообщение о завершении команды посылается пос-

узнавать о приближении конца носителя, для чего определяется позиция раннего предупреждения EW (Early Warning) с соответствующим маркером. Это позволяет после записи блока данных из буфера поместить на носитель соответствующий концевой маркер. Том может иметь один или несколько разделов (Partitions), нумеруемых с нуля. Разделы располагаются друг за другом, без перекрытия. Каждый раздел x имеет

начало BOP x (Begining-Of-Partition x), конец EOP x и раннее предупреждение EW x. Между началом и концом разде-

ет начало носителя BOM (beginning-of-medium) и конец носителя EOM (end-of-medium). При записи ИУ должен заранее

ла помещаются блоки данных и маркеры. Блоки данных, передаваемые ИУ, называются логическими. Логический блок может занимать один или несколько физических блоков данных на носителе, в последнем случае за блокирование-деблокирование отвечает ЦУ. Описатели записанных физических и/или логических блоков могут храниться на носителе (определяется форматом записи). Буфер устройства должен

вмещать по крайней мере один логический блок.

ко двунаправленная связь по шине позволяет ввести дополнительные команды, служащие для отслеживания состояния принтеров с буферной памятью, и обеспечить целостность заданий. Принтеры могут иметь встроенный контроллер SCSI или подключаться ЛУ к внешнему контроллеру по интерфейсу Centronics или RS-232. Параметры подключения определяются командой MODE SELECT. Процессорными устройствами (3) в терминологии SCSI являются источники и потребители пакетов информации, трактовка которой стандартом не определена. Примерами процессорных устройств являются компьютеры, обменивающиеся сообщениями односторонним или двухсторонним образом. Процессорным устройством является и какое-либо сложное устройство отображения (графический дисплей), которое занято выводом потока сообщений. От коммуникационных устройств процессорные отличаются тем, что они являются источниками или потребителями информации, в то время как коммуникационные служат лишь посредниками. Устройства оптической памяти (7) близки к устройствам прямого доступа со сменными носителями, но имеют ряд характерных особенностей. Большая емкость носителя вызывает необходимость применения команд с 12-байтным дескриптором. Устройства могут обеспечивать считывание, однократную или многократную запись. На носителе могут быть определены зоны, недоступные для записи. Блоки носителя имеют состояние «чистый» и «записанный», что отмечается соответствующим атрибутом. Для устройств многократной записи перед повторной записью блока необходимо его стереть. Стирание может выполняться специальной командой или автоматически по команде записи. В записи фаза стирания может отсутствовать. К этим устройствам применимо понятие обновления (update) логического блока — запись новых данных по тому же адресу логического блока, но на другое место носителя. Прежние данные могут быть считаны специальной командой,

указывающей кроме логического адреса блока и его *поколе*ние (generation). Емкость носителя в таком случае сообщает-

Принтеры (2), подключаемые через интерфейс SCSI, не требуют особых команд для управления, поскольку эти функции реализуются через поток передаваемых данных. Однаные алгоритмы восстановления информации. Устройства однократной записи (4), обычно оптические, отличаются невозможностью перезаписи ранее записанного блока. Попытка повторной записи в зависимости от реализации устройства может приводить к потере записанных данных. Каждый блок имеет состояние «записан» или «не записан», инициализация (форматирование) не применяется. Приводы CD-ROM (5) предназначаются для работы с CD-

дисками. Изначально диски содержали звукозапись и приводы были рассчитаны не только на чтение блоков данных, но и на потоковый вывод на внешний аудиоинтерфейс. Запись не предусмотрена. Данные на диске адресуются по-разному. Физический сектор имеет 2352 байт, из которых обычно используется 2048, поле синхронизации 12 байт и поле тега адреса сектора 4 байт. Дополнительное поле 288 байт используется для исправления ошибок данных, но если ошибки допустимы, его тоже используют для хранения данных. Таким

ся без учета множества поколений. Оптические носители по сравнению с магнитными имеют существенно более высокий уровень ошибок, так что приходится использовать более слож-

образом, физический сектор данных может иметь размер 2048 байт (CD-ROM Data Mode 1) или 2336 и даже 2340 (вместе с полем тега) байт (CD-ROM Data Mode 2). В зависимости от размера логического блока (1024, 512 или 256 байт) сектор может вмещать 2, 4 или 8 блоков. Один сектор, или кадр (frame), аудиодиска хранит 1/75 с

звукозаписи. От этого происходит адресация MSF: 75 смежных кадров, адресуемых полем F (0-74), объединяются в более крупную единицу, адресуемую полем S (0-59), звучащую 1 с. 60 полей S соответствуют полю M (0-74),

звучащему 1 мин. Адресация MSF может использоваться как абсолютная или относительно начала трека. Носитель делится на треки (track), характерные однотипностью записанной информации. Каждый трек (они нумеруются от 1 до 99) делится на последовательно нумеруемые

(1–99) индексы (*index*). Носитель CD-ROM и CD-DA кроме основного канала имеет субканал (sub-channel), разделенный на 8 частей, называ-

изображение сканируемого объекта. Команды позволяют задавать окна сканирования, определяя в них режим и разрешение. Для некоторых функций требуется посылка данных в сканер (например, полутоновые маски). Для сканеров с автоподачей имеются команды позиционирования. Устройства смены носителей (8) предназначены для автоматического манипулирования сменными носителями — дисками и картриджами с магнитными лентами. В SCSI они

емых P, Q, R, S, T, U, V и W. К примеру, часть Q несет информацию для контроллера и привода — управляющие поля и MSF-адрес. Каждая часть имеет производительность, рав-

Сканеры (6) передают ИУ данные, описывающие растровое

ную 1/192 основного канала.

состоит из набора адресуемых элементов, каждый из которых может «держать» только одну единицу носителя:

Мedium Transport Element — элемент транспортировки носителя:

Storage Element — место хранения единицы носителя, ког-

представляются ЛУ, отличающимися от *первичных устройств* хранения, которые они обслуживают. Модель устройства

- да он не находится ни в одном из элементов трех других типов;

  Import Export Element элемент, с помощью которого
- устройство принимает носители извне или отдает их;

  Data Transfer Element позиция первичного устройства,
- осуществляющего обмен данными с носителем. Элементы адресуются 16-битными адресами; доступна информация об их состоянии. Каждый том носителя снабжается идентификатором-тегом, по которому определяется его

нахождение в элементах. Коммуникационные устройства (9) предназначены для обмена информацией с устройствами через внешнюю по отношению к шине SCSI среду передачи данных. Внешние протоколы стандартом SCSI не описываются: вся необходимая

токолы стандартом SCSI не описываются: вся необходимая для них информация заключена в сообщениях, передаваемых и принимаемых ИУ по командам SEND MESSAGE и GET MESSAGE.

### 5.5. Адресация и система команд

ресуется идентификатором SCSI ID, соответствующим заданному уникальному адресу. В ЦУ может быть определено до 8 ЛУ со своими номерами LUN (Logical Unit Number) в диапазоне 0–7. Понятие LUN неприменимо к ИУ, но SCSI-устройство двойного назначения может иметь ЛУ.

Как указывалось ранее, любое устройство SCSI на шине ад-

Система команд и сообщений позволяет адресовать как ЦУ в целом, так и любое его ЛУ. В ЦУ может быть определено до 8 *целевых программ TRN (Target Routine)*, которые не имеют непосредственной привязки к ЛУ. Целевые программы появились в SCSI-2, их адресация также производится челез сообщения

рез сообщения. Система команд SCSI включает общие команды, применимые для устройств всех классов, и специфические для каждого класса. Как общие, так и специфические наборы команд содержат обязательные (Mandatory), дополнительные (Optional) и фирменные (Vendor Specific) команды. Любое SCSI-устройство должно поддерживать обязательные команды общего набора и своего класса, чем обеспечивается высокий уровень совместимости. Команда передается ИУ в ЦУ через блок дескриптора команды Сотта Descriptor Block, посылаемый в фазе Command. Некоторые команды сопровождаются блоком параметров, следующим за блоком дескриптора в фазе Data. Форматы блоков стандартизованы, длина блока определяется кодом операции Operation Code, который всегда является

Типовой блок содержит следующие поля (рис. 5.8): OpCode — код операции, 1 байт (графа «Код» в табл. 5.14). Биты [7:5] определяют группу, а биты [4:0] — код команды. В группе 0 блок дескриптора имеет длину 6 байт, в группах 1 и 2 — 10 байт, в группе 5 — 12 байт. Группы 3 и 4 зарезерви-

первым байтом блока и может составлять 6, 10 или 12 байт.

рованы, группы 6 и 7 отданы на усмотрение разработчиков. LUN — номер ЛУ (для совместимости со SCSI-1), всегда занимает биты [7:5] байта 1. Если для идентификации используются сообщения *Identify*, то это поле игнорируется (рекомендуется устанавливать LUN=0). поле не используется.

\*\*Length — длина (количество блоков или байт) передаваемых данных Transfer Length, блока параметров Parameter List Length или блока, резервируемого ИУ под данные Allocation Length (один из трех вариантов в зависимости от команды). При однобайтном задании длины 0 соответ-

ствует значению 256, в длинных формах 0 указывает на отсутствие передач. В ряде команд поле не используется. Control — байт управления. Биты [7:6] отданы на усмотрение разработчику, биты [5:2] — зарезервированы, бит 1 — Flag, бит 0 — Link (служит признаком объединения команд

*LBA* — адрес логического блока, 21 бит для 6-байтных блоков и 32 бит — для 10- и 12-байтных. В ряде команд

в цепочку). Flag определяет сообщение, передаваемое в случае успешного выполнения команд цепочки, при Flag=1 сообщение Linked Command Complete (With Flag) будет вызывать прерывания между командами цепочки. 76543210 76543210 76543210 Op Code On Code Op Code 0 0 LUN (MSB) LUN LUN 1 1 Резерв 1 Резерв (MSB) 2 (MSB) 2 LBA 3 (LSB 3 3 - LBA - LBA Length 4 4 4 5 Control 5 (LSB) 5 (LSB) (MSB) Резерв 6 6

Length

Control

б

(LSB

7

8

9

10

11

Length

Резерв

Control

(LSB)

**Рис. 5.8.** Форматы блоков дескрипторов команд: a-6 байт, b-10 байт, b-12 байт

7 (MSB)

8

9

нулевые значения.

Обратим внимание на порядок байт: первыми передаются старшие байты (бит MSB — самый старший), за ними — младшие (бит LSB — самый младший). Зарезервированные поля для совместимости с будущими стандартами должны иметь

байта состояния Status Byte. Байт не передается, если команда завершена по сообщению Abort, Abort Tag, Bus Device Reset, Clear Queue, по условию Hard Reset или в случае неожиданного разъединения. В байте состояния используются только биты [5:1], возможные состояния приведены в табл. 5.13 (остальные зарезервированы).

Исполнение команды завершается в фазе Status передачей

R R O 1 O 1 O R

R R O 1 1 0 O R

Intermediate

Reservation

Conflict

Condition Met

| Биты  |   | Состояние | Значение |   |   |                                               |                                                                  |  |
|-------|---|-----------|----------|---|---|-----------------------------------------------|------------------------------------------------------------------|--|
| 765   | 4 | 3         | 2        | 1 | 0 | İ                                             |                                                                  |  |
| RR0   | 0 | 0         | 0        | 0 | R | Good                                          | Успешное завершение команды                                      |  |
| R R O | 0 | 0         | 0        | 1 | R | Check Condition Указание на асинхронное событ |                                                                  |  |
| R R O | 0 | 0         | 1        | 0 | R | Condition Met                                 | Запрошенная операция выполнена (команды Search Data и Pre-Fetch) |  |
| RR0   | 0 | 1         | 0        | 0 | R | Busy                                          | Занято (невозможен прием команды)                                |  |
| RR0   | 1 | 0         | 0        | 0 | R | Intermediate                                  | Успешное выполнение команды<br>в цепочке                         |  |

Удовлетворение запрошенной опера-

Попытка обратиться к ЛУ, зарезер-

ции в цепочке команд

вированному другим ИУ

|                       | Cong nee              | пированному другим из                                                                       |
|-----------------------|-----------------------|---------------------------------------------------------------------------------------------|
| R R 1 0 0 0 1 R       | Command<br>Terminated | Завершение текущего процесса по сообщению Terminate I/O Process или по асинхронному событию |
| R R 1 0 1 0 0 R       | Queue Full            | Очередь (маркированная) заполнена, процесс в очередь не поставлен                           |
| ——————<br>Набор коман | д лля vстр            | ойств классов 0-9 привелен в                                                                |

табл. 5.14. Любое ЦУ SCSI-2 обязано поддерживать четыре команды: Inquiry, Request Sense, Send Diagnostic, Test Unit Ready. Они используются для конфигурирования системы,

тестирования устройств и сообщений об ощибках и исключительных ситуаций. Команда Inquiry позволяет получить информацию о ЛУ через стандартизованный блок данных длиной 96 байт: тип подключенного ПУ, возможность смены носителя, поддержка 32- или 16-битного расширения, синхронного обмена, относительной адресации, цепочек ко-

манд, очередей и уведомления об асинхронных событиях.

Здесь же описываются уровень поддержки стандартов SCSI (ISO, ANSI, ECMA), идентификаторы производителя, устройства и т. п. Формат блока по усмотрению производителя может быть расширен.

В графе «Применимость» указаны номера типов ПУ, соответствующие табл. 5.12 (символ \* соответствует всем типам). Команды для каждого типа устройств могут быть обязательными — номер сопровождается символом

(Mandatory) — или необязательными — номер типа сопровождается символом о (Optional). Часть команд в устройствах разных классов реализуется по-разному, что отмечено обозначением \*z.

Применимость

\*n

Назначение

Модификация

операций для ЛУ

определений

# Таблица 5.14. Команды SCSI

Команда

Change

Definition

Код

40h

| Compare         | 39n | T-0 | Пооаитное сравнение данных двух ЛУ <sup>1</sup>                                |
|-----------------|-----|-----|--------------------------------------------------------------------------------|
| Сору            | 18h | *0  | Копирование данных с одно-<br>го ЛУ на другое <sup>1</sup>                     |
| Copy And Verify | 3Ah | *0  | Копирование данных с одно-<br>го ЛУ на другое с верифи-<br>кацией <sup>1</sup> |
| Erase           | 19h | 1m  | Стирание (участка или до конца посителя)                                       |

Erase (10) 2Ch То же с 10-байтным блоком 7o дескриптора Erase (12) **ACh** 7<sub>0</sub> То же с 12-байтным блоком дескри птора A6h Exchange 80 Обмен носителями

Medium двумя элементами устройства **Format** 04h 20 Выбор шрифтов и форм 0m 7o Format Unit 04h

Форматирование устройства Get Data Buffer 34h буфера 60 Опрос состояния

данных

Status

Get Message 08h 90 Прием пакета из коммуникационного устройства

Таблица 5.14 (продолжение) Код Применимость Назначение Команда Get Mess

Get Window

| Get Message         | 28h | 90 | То же с 10-байтным блоком             |
|---------------------|-----|----|---------------------------------------|
| (10)                |     |    | дескриптора                           |
| Get Message<br>(12) | A8h | 90 | То же с 12-байтным блоком дескриптора |

Получение

ном окне

о предварительно

Загрузка/разгрузка носителя

на заланный логический блок

блоков

информации с ЦУ или ЛУ

или записанных блоков

Сканирование — поиск непрерывной области

устройства и ее отмена

заланных

статистической формации, обработка которой поддерживается устройством,

В

статистической

чистых

Позиционирование

Фиксания

ческих

Запись

в ЦУ или ЛУ

Считывание

информации

определен-

состояния

логи-

кэше

идентифика-

25h 60 07h 80

Initialize Инициализация Element Status элемента 12h \*m Inauiry Опрос типа устройства, уровня стандарта, тора производителя, модели и т. п.

10

10

\*0

\*0

00 40 50 70

Load Unload 1Bh Locate 2Bh Lock-Unlock 36h Cache

Loà Select

Loa Sense

Medium Scan

4Ch

4Dh 38h

40 70 Mode Select (6) 15h

\*z

ЦУ или ЛУ (с 6-байтным

Запись параметров носителя,

ЛУ

блоком дескриптора) Mode Select 55h \*7. То же с 10-байтным блоком (10)дескриптора \*7. Mode Sense (6) 1 Ah Считывание параметров ПУ носителя. или (с 6-байтным блоком дескриптора)

| Команда                            | Код | Применимость         | Назначение                                                                   |
|------------------------------------|-----|----------------------|------------------------------------------------------------------------------|
| Mode Sense<br>(10)                 | 5Ah | *Z                   | То же с 10-байтным блоком дескриптора                                        |
| Move Medium                        | A5h | 8m                   | Передача посителя                                                            |
| Object Position                    | 31h | 60                   | Позиционирование (загруз-<br>ка/выгрузка) сканируемого<br>объекта            |
| Pause/Resume                       | 4Bh | 50                   | Пауза/продолжение воспро-<br>изведения аудио                                 |
| Play Audio (10)                    | 45h | 50                   | Аудиовоспроизведение ука-<br>занных логических блоков                        |
| Play Audio (12)                    | A5h | 50                   | То же с 12-байтным блоком дескриптора                                        |
| Play Audio MSF                     | 47h | 50                   | Аудиовоспроизведение с адре-<br>сацией MSF                                   |
| Play Audio<br>Track/Index          | 48h | 50                   | Аудиовоспроизведение с ука-<br>занием треков и индексов                      |
| Play Track<br>Relative (10)        | 49h | 50                   | Аудиовоспроизведение с адресацией относительно трека                         |
| Play Track<br>Relative (12)        | A9h | 50                   | То же с 12-байтным блоком дескриптора                                        |
| Position To<br>Element             | 2Bh | 80                   | Позиционирование транс-<br>портного элемента к указан-<br>ному элементу      |
| Pre-Fetch                          | 34h | 00 40 50 70          | Считывание блоков данных в кэш (без передачи ИУ)                             |
| Prevent Allow<br>Medium<br>Removal | 1Eh | 0o 1o 4o 5o 7o<br>8o | Запрет/разрешение смены<br>носителя в ЛУ                                     |
| Print                              | 0Ah | 2m                   | Печать блока данных                                                          |
| Read (6)                           | 08h | 0m 1m 4o 5o<br>7o    | Чтение данных (с 6-байтным блоком дескриптора)                               |
| Read ( 10)                         | 28h | 0m 4m 5m 6m<br>7m    | То же с 10-байтным блоком дескриптора                                        |
| Read ( 12)                         | A8h | 40 50 70             | То же с 12-байтным блоком дескриптора                                        |
| Read Block<br>Limits               | 05h | 1m                   | Запрос ограничений на дли-<br>ну блока (минимальная и<br>максимальная длины) |

| Таблица 5.14 (продолжение) |             |              |                                                                                                                         |  |  |
|----------------------------|-------------|--------------|-------------------------------------------------------------------------------------------------------------------------|--|--|
| Команда                    | Код         | Применимость | Назначение                                                                                                              |  |  |
| Read Buffer                | 3Ch         | *0           | Чтение буфера                                                                                                           |  |  |
| Read Capacity              | 25h         | 0m 4m 7m     | Определение емкости ЛУ                                                                                                  |  |  |
| Read Cd-Rom<br>Capacity    | 25h         | 5m           | Определение емкости<br>CD-ROM (возможно быстрое<br>определение с погрешностью)                                          |  |  |
| Read Defect<br>Data        | 37h         | 00 70        | Чтение списков дефектных блоков (Plist — исходный список от изготовителя, Glist — список, заполняемый при эксплуатации) |  |  |
| Read Defect<br>Data (12)   | B7h         | 70           | То же с 12-байтным блоком дескриптора                                                                                   |  |  |
| Read Element<br>Status     | B8h         | 80           | Чтение состояния элементов                                                                                              |  |  |
| Read<br>Generation         | 29h         | 70           | Чтение максимально возможного поколения для указанного логического блока                                                |  |  |
| Read Header                | <b>44</b> h | 50           | Чтение заголовка логического<br>блока CD-ROM                                                                            |  |  |
| Read Long                  | 3Eh         | 0o 4o 5o 7o  | «Длинное» чтение — данные блока и поля ЕСС                                                                              |  |  |
| Read Position              | 34h         | 10           | Запрос позиции данных, находящихся в буфере (адрес начала и конца, количество блоков и байт)                            |  |  |
| Read Reverse               | 0Fh         | 10           | Чтение блоков с текущей по-<br>зиции в обратном направ-<br>лепии                                                        |  |  |
| Read<br>Sub-Channel        | 42h         | 50           | Чтепие данных субканала<br>CD-ROM                                                                                       |  |  |
| Read Toc                   | 43h         | 50           | Чтение таблицы содержимого CD-ROM                                                                                       |  |  |
| Read Updated<br>Block      | 2Dh         | 70           | Чтение определенного поко-<br>ления обновленного логичес-<br>кого блока                                                 |  |  |
| Reassign Blocks            | 07h         | 00 40 70     | Переназначение дефектных                                                                                                |  |  |

блоков

| Команда                              | Код | Применимость               | Назначение                                                                                             |
|--------------------------------------|-----|----------------------------|--------------------------------------------------------------------------------------------------------|
| Receive                              | 08h | 30                         | Прием пакета                                                                                           |
| Receive<br>Diagnostic<br>Results     | 1Ch | *0                         | Получение результатов диа-<br>гностики                                                                 |
| Recover<br>Buffered Data             | 14h | 10 20                      | Восстановление данных, по-<br>сланных в буфер, но не запи-<br>санных (не напечатанных)<br>из-за ошибки |
| Release                              | 17h | 0m 2m 4m 5m<br>6m 7m 8o    | Освобождение зарезервированного ЛУ, экстента или элемента                                              |
| Request Sense                        | 03h | *m                         | Опрос уточненного состояния                                                                            |
| Request Volume<br>Element<br>Address | B5h | 80                         | Передача результатов команды SEND VOLUME TAG                                                           |
| Reserve                              | 16h | 0m 1m 2m 4m<br>5m 6m 7m 8o | Предотвращение использования ЛУ (его экстента или элемента) другим ИУ                                  |
| Rewind                               | 01h | 1m                         | Перемотка носителя к началу раздела                                                                    |
| Rezero Unit                          | 01h | 0o 4o 5o 7o 8o             | Приведение ЛУ в определен-<br>ное состояние                                                            |
| Scan                                 | 1Bh | 60                         | Сканирование данных в<br>определенном окне                                                             |
| Search Data<br>Equal                 | 31h | 00 40 50 70                | Поиск данных, (не) совпадающих с эталоном <sup>2</sup>                                                 |
| Search Data<br>Equal (12)            | B1h | 40 50 70                   | То же с 12-байтным блоком дескриптора <sup>2</sup>                                                     |
| Search Data<br>High                  | 30h | 00 40 50 70                | Поиск данных, (не) больших эталона <sup>2</sup>                                                        |
| Search Data<br>High (12)             | B0h | 40 50 70                   | То же с 12-байтным блоком дескриптора <sup>2</sup>                                                     |
| Search Data<br>Low                   | 32h | <b>0</b> o 5o 7o           | Поиск данных, (не) меньших эталопа <sup>2</sup>                                                        |
| Search Data<br>Low (12)              | B2h | 40 50 70                   | То же с 12-байтным блоком дескриптора <sup>2</sup>                                                     |
| Seek (6)                             | 0Bh | 00 40 50 70                | Позиционирование (с 6-байт-<br>ным блоком дескриптора) <sup>3</sup>                                    |

Таблица 5.14 (продолжение) Код Применимость Назначение Команда Позиционирование - поиск Seek (10) 0o 4o 5o 7o 2Rh логического алреса (с 10-байтным блоком дескриптора) $^3$ Send 0Ah 3mПосылка пакета Посылка данных в устройство Send (10) 2Ah 60 Send Diagnostic 1 Dh \*m Запуск теста ПУ. Ответом будет состояние Good, если тест прошел успешно, Check Condition случае ошибки Send Message 0Ah9m Посылка пакета в коммуникационное устройство Send Message То же с 10-байтным блоком 2Ah 9ο (10)дескриптора Send Message То же с 12-байтным блоком AAh 90 (12)дескриптора Send Volume B6h 80 Посылка тега тома (шаблона) Tag для поиска его в элементах или созлания нового тега Set Limits 33h 0o 4o 5o 7o Определение области логических адресов, над которыми могут выполняться операции пепочки команд B3h Set Limits (12) 4o 5o 7o То же с 12-байтным блоком дескриптора Set Window 24h бm Определение окна сканирования 20 Slew And Print 0Bh Прогон бумаги и печать 11h 1 m Space Относительное позинионирование (вперед и назад) на блоков. заланное число файлов, маркеров и т. п. Start Stop Unit 1Bh 00 40 50 70 Разрешение/запрет операций с носителем, извлечение носителя<sup>4</sup> Stop Print 1Bh 20 Останов печати с очисткой буфера или без нее

| Команда                  | Код | Применимость     | Назначение                                                                               |
|--------------------------|-----|------------------|------------------------------------------------------------------------------------------|
| Synchronize<br>Buffer    | 10h | 20               | Синхронизация буфера— печать всего содержимого, при невозможности— сооб- щение об ошибке |
| Synchronize<br>Cache     | 35h | 00 40 50 70      | Синхронизация кэша— запись несохраненных данных заданного диапазона адресов на поситель  |
| Test Unit Ready          | 00h | *m               | Опрос готовности ЛУ                                                                      |
| Update Block             | 3Dh | 70               | Обновление логического<br>блока                                                          |
| Verify                   | 2Fh | 00 50 70         | Верификация — проверка возможности безошибочного считывания блоков данных с носителя     |
| Verify                   | 13h | 10               | То же                                                                                    |
| Verify (10)              | 2Fh | <b>4</b> o 5o 7o | То же или проверка чистоты блоков (с 10-байтным блоком дескриптора)                      |
| Verify (12)              | AFh | 40 50 70         | То же с 12-байтным блоком дескриптора                                                    |
| Write (6)                | 0Ah | 0o 1m 4o 7o      | Запись блоков данных,<br>переданных ИУ (с 6-байт-<br>ным блоком дескриптора)             |
| Write (10)               | 2Ah | 0o 4m 7m         | Запись блоков данных,<br>переданных ИУ (с 10-байт-<br>ным блоком дескриптора)            |
| Write ( 12)              | AAh | 40 70            | То же с 10-байтным блоком дескриптора                                                    |
| Write And Verify         | 2Eh | 00 40 70         | Запись блоков данных, переданных ИУ, с верификацией записи                               |
| Write And Verify<br>(12) | AEh | 70 40            | То же с 12-байтным блоком дескриптора                                                    |
| Write Buffer             | 3Bh | *0               | Запись в буфер (но пе<br>на носитель) или загрузка<br>микрокода                          |

#### Таблица 5.14 (продолжение)

| Команда         | Код | Применимость | Назначение                                                                                     |
|-----------------|-----|--------------|------------------------------------------------------------------------------------------------|
| Write Filemarks | 10h | 1m           | Запись маркера файлов                                                                          |
| Write Long      | 3Fh | 00 40 70     | «Длипная» запись — блока дапных и поля ЕСС                                                     |
| Write Same      | 41h | 00           | Запись блока данных, переданных ИУ, в группу смежных блоков или до конца носителя <sup>5</sup> |

<sup>1</sup> Команды копирования и сравнения данных оперируют парой ЛУ, которые могут принадлежать как одному ЦУ, так и разным, если эту воз-

## 5.6. Выполнение команд

Мы не будем рассматривать различные ситуации, приводящие к отклонениям от нормальной последовательности событий интерфейса. К ним относятся некорректные соединения со стороны ИУ, выбор несуществующего ЛУ, неожиданные выборки ИУ, округление параметров, реакция на асинхронные события и т. п

на асинхронные события и т. п. Рассмотрим процесс на шине SCSI на примере одиночной команды итения Read. ИУ имеет активный набор указателей и несколько сохраненных наборов, по одному на каждый из допустимого числа одновременных конкурирующих процессов. ИУ восстанавливает указатели процесса в активный набор и, выиграв арбитраж, выбирает ЦУ. Как только

можность поддерживает ведущее устройство копирования — *Copy Master*. Копирование возможно между устройствами любых классов. Для устройств типов 8 и 9 эти команды не применяются.

2 Данные ищутся сравнением указанного числа логических записей с

эталоном. Логические записи определяются длиной, начальным логическим блоком и смещением внутри него. Можно потребовать попадания искомых данных в один логический блок.

 <sup>&</sup>lt;sup>3</sup> Команда эффективна для ленточных устройств прямого доступа.
 <sup>4</sup> Команда STOP UNIT для устройств с кошированием перед остановом

автоматически выполняет синхронизацию кэша.

<sup>&</sup>lt;sup>5</sup> Первые 4 байта в записываемых блоках могут быть заменены на физический или логический адрес блока.

ние Command Complete, после чего освобождает шину (фаза Bus Free). Процесс завершен. Рассмотрим тот же пример, но с использованием отключения om шины (Disconnect) в процессе выполнения команды. Если устройство определит, что для получения затребованных данных потребуется много времени, получив команду Read, оно освобождает шину, послав сообщение Disconnect. Как только требуемые данные готовы в ЦУ, оно, выиграв арбитраж, выберет ИУ (в фазе Reselect) и в фазе Message IN пошлет ему сообщение Identify. По определенной этим сообщением связи / Т L ИУ восстановит соответствующий набор указателей в активный и продолжит выполнение процесса, как описано выше. Если ЦУ хочет отсоединиться, когда часть данных уже передана (например, головка дошла до конца цилиндра и требуется время на позиционирование), оно посылает сообщение Save Data Pointer, а затем Disconnect. После повтор-

ного соединения передача данных возобновится с точки, определенной последним сохраненным значением указателя. Если произошла ошибка или исключение, ЦУ может повторить обмен данными, послав сообщение Restore Pointers или отсоединившись без сообщения Save Data Pointers. Теперь рассмотрим процесс с цепочкой связанных команд. По успешному завершению каждой команды цепочки ЦУ автоматически переходит к исполнению следующей. Все команды цепочки адресуются к одной и той же связи I\_T\_х и яв-

ЦУ выбрано, оно берет на себя управление процессом. В фазе Selection ИУ вводит сигнал ATN#, сообщая о намерении послать сообщение Identify с указанием адресуемого ЛУ. Таким образом устанавливается связь I\_T\_L с данным процессом и его набором указателей. ЦУ переходит в фазу Command и принимает блок дескриптора команды Read. Интерпретировав команду, ЦУ переходит в фазу Data IN, передает данные, затем переводится в фазу Status и посылает состояние Good. Затем в фазе Message IN устройство посылает сообще-

ляются частью одного процесса. Команды не являются полностью независимыми: при использовании бита относительной адресации последний блок, адресованный предыдущей командой, доступен для следующей. Так, например, можно исполнить команду Search Data, по которой на диске будет

ЦУ посылает сообщения Linked Command Complete (возможно, с флагом), а ИУ обновляет набор сохраненных указателей так, что они указывают на очередную команду цепочки. Команды в цепочке выполняются как одиночные, но с возможностью относительной адресации.

Команды могут исполняться с использованием очередей. ЦУ могут поддерживать немаркированные и маркированные

очереди. Поддержка немаркированных очередей, определен-

найден блок, содержащий информацию, совпадающую с эталоном поиска. Связав с ней команду чтения *Read*, можно прочитать этот блок или блок с указанным смещением относительно найденного. По выполнении связанных команд

ная еще в SCSI-1, позволяет любому ЛУ (*LUN*) или целевой программе (*TRN*), занятым процессом от одного ИУ, принимать команды (начинать процесс) с другими ИУ. При этом каждый процесс идентифицируется связью *I\_T\_x*, где х — *LUN* или *TRN*.

Маркированные очереди (*Tagged Queue*) определены в SCSI-2 для ЛУ (*LUN*, но не *TRN*). Для каждой связи *I T L* суще-

ствует своя очередь размером до 256 процессов (немаркированные очереди можно считать вырожденным случаем мар-

кированных с одноместными очередями). Каждый процесс, использующий маркированные очереди, идентифицируется связью *I\_T\_L\_Q*, где Q — однобайтный тег очереди (*Queue Tag*). Теги процессам назначаются ИУ, их значения на порядок выполнения операций не влияют. Повторное использование тега возможно лишь по завершении процесса с этим тегом. Постановка в очередь выполняется через механизм сообще-

Постановка в очередь выполняется через механизм сообщений, при этом очередной процесс можно поставить в очередь «по-честному», а можно пропихнуть вне очереди: процесс, поставленный в очередь с сообщением Head Of Queue Tag, будет выполняться сразу после завершения текущего активного процесса. Процессы, поставленные в очередь с сообщением Simple Queue Tag, исполняются ЦУ в порядке, который оно сочтет оптимальным. Процесс, поставленный в

очередь с сообщением Ordered Queue Tag, будет исполняться последним. ИУ может удалить процесс из очереди, сославшись на него по тегу. Изменение порядка выполнения команд ЦУ не касается порядка команд в цепочке, поскольку

цепочка принадлежит одному процессу, а в очередь ставятся именно процессы.

## 5.7. Конфигурирование устройств SCSI

Все устройства на шине должны быть согласованно сконфигурированы. Для них требуется программно или с помощью джамперов установить следующие основные параметры: Идентификатор устройства SCSI ID — адрес 0–7 (для Wide SCSI 0–15) димерт и и и при должного устройства 
Идентификатор устройства SCSI ID — адрес 0–7 (для Wide SCSI 0–15), уникальный для каждого устройства на шине. Обычно хост-адаптеру, который должен иметь высший приоритет, назначается адрес 7 (15 для Wide SCSI, если все устрой-

ства 16-битные). Позиционный код, используемый для адресации, обеспечивает совместимость адресации 8- и 16-битных устройств на одной шине. Типовые заводские назначения идентификаторов устройств приведены в табл. 5.15, хотя они не являются обязательными. В настоящее время прорабатывается спецификация PnP для устройств SCSI, позволяющая автоматизировать процесс назначения идентификаторов. Она

устройств, идентификаторы которых задаются джамперами, с автоматически конфигурируемыми PnP-устройствами. Контроль паритета — SCSI Parity. Если хотя бы одно устройство не поддерживает контроль паритета, он должен быть отключен для всех устройств на шине. Контроль паритета, особенно для дисковых устройств, является надежным средством защиты от искажения данных при передаче по шине.

обеспечивает сосуществование традиционных (Legacy SCSI)

Включение терминаторов — Termination. В современных устройствах применяются активные терминаторы, которые могут включаться одним джампером или программно управляемым сигналом. Терминаторы включаются только на крайних устройствах в цепочке. Современные хост-адаптеры позволяют автоматически включать свой терминатор, если они являются крайними, и отключать, если используются внутренний и внешний разъем канала. Это позволяет под-

внутреннии и внешнии разъем канала. Это позволяет подключать и отключать внешние устройства, не заботясь о переключении терминаторов. Ранее приходилось открывать корпус и переставлять джампер, а пассивные терминаторы устанавливать в специальные гнезда (и извлекать их оттуда). При отсутствии внутренних терминаторов пользователь вынужден был использовать внешние, устанавливаемые на кабель.

Правильная установка терминаторов крайне существенна — отсутствие/избыток тер-

Правильная установка терминаторов крайне существенна — отсутствие/избыток терминаторов может привести к неустойчивости или неработоспособности интерфейса.

Питание терминаторов (Terminator Power). Когда используются активные терминаторы (для современных устройств —

всегда), питание терминаторов должно быть включено (джампером или программно) хотя бы на одном устройстве. Согласование скорости синхронного обмена (SCSI Synchronous Negotiation). Режим синхронного обмена, обеспечивающий высокую производительность, включается по взаимному согласию устройств. Если хотя бы одно устройство на шине его не поддерживает, рекомендуют согласование запретить на хост-адаптере. Если обмен будет инициирован синхронным устройством, хост-адаптер поддержит этот режим. Старт по команде (Start on Command) или задержанный

двигателя устройства выполняется только по команде от хост-адаптера, что позволяет снизить пик нагрузки блока питания в момент включения. Хост будет запускать устройства последовательно.

Разрешение отключения (Enable Disconnection). Позволяет устройствам отключаться от шины при неготовности данных во время длительных операций с носителем, что весьма эффек-

cmapm (Delayed Start). При включении этой опции запуск

троиствам отключаться от шины при неготовности данных во время длительных операций с носителем, что весьма эффективно в многозадачном режиме при нескольких ПУ на шине. В случае одного устройства отключение приводит только к дополнительным затратам времени на повторное соединение.

| SCSI ID | Устройство                              |
|---------|-----------------------------------------|
| 7       | Хост-адантер                            |
| 6       | Накопитель на магнитных дисках          |
| 5       |                                         |
| 4       | Лепточный или R/W-оптический пакопитель |
| 3       | CD-ROM                                  |

|   | 1                | НЖМД, поддерживаемый BIOS хост-адаптера                  |    |
|---|------------------|----------------------------------------------------------|----|
|   | 0                | НЖМД, поддерживаемый BIOS хост-адаптера                  |    |
|   | <b>У</b> стройс: | гва SCSI допускают программирование — <i>Programma</i>   | bl |
|   |                  | g <i>Definition</i> . Программированием определений опер |    |
| 1 | ций для          | ЛУ можно изменить такие параметры, как идент             | и  |
| • | фикания          | н производителя, типа и модели устройства, урове         | н  |

временных диаграмм, определение паритета) сохраняются неизменными. Текущие определения могут быть считаны ИУ по командам Inquiry, Mode Sense и Read Capacity.

соответствия SCSI, номер спецификации, набор команд и т. д. Однако низкоуровневые параметры интерфейса (параметры

## 5.8. Хост-адаптер SCSI

**Устройство** Сканер, принтер

SCSI ID

Хост-адаптер является важнейшим узлом интерфейса, определяющим производительность системы SCSI. Существует широкий спектр адаптеров. К простейшим можно подключать только устройства, не критичные к производительности. Такие адаптеры входят в комплект поставки сканеров, а подключение к ним диска невозможно. Высокопроизводительные адаптеры

имеют собственный специализированный процессор, большой

объем буферной памяти и используют высокоэффективные режимы прямого управления шиной для доступа к памяти компьютера. Адаптеры SCSI существуют для всех шин: ISA (8-16 бит), EISA, MCA, PCI, VLB, PCMCIA и для параллельпорта. Ряд системных плат имеют

SCSI-адаптер, подключенный к одной из локальных шин. При выборе интерфейса, к которому подключается хост-адаптер, учитывайте производительность — интерфейс не должен стать узким местом при обмене с высокопроизводительными устройствами SCSI. Наибольшую эффективность имеют хост-адаптеры для шины РСІ. Конечно, за мощный адаптер для сервера приходится платить — его цена может превышать цену рядового настольного компьютера. Еще дороже хост-адаптеры со встроенными контроллерами RAID-массивов, которые содержат мощный RISC-процессор и большой объем локальной памяти. Для современных адаптеров вместо джамперов используется программное конфигурирование. Утилита конфигурирования обычно входит в расширение BIOS, установленное на плате адаптера, и приглашение к ее вызову выводится на экран во время POST.

Как и всякая карта расширения, хост-адаптер должен быть

Конфигурирование хост-адаптеров с точки зрения шины SCSI не отличается от конфигурирования других устройств.

сконфигурирован и с точки зрения шины расширения, к которой он подключается. Системные ресурсы для шинного SCSI-адаптера включают:

« область памяти для расширения ROM BIOS, необходимого для поддержки конфигурирования устройств и дис-

- ковых функций. Если в системе установлено несколько однотипных хост-адаптеров, ROM BIOS для них используется с одного адаптера. Разнотипные хост-адаптеры не всегда могут работать вместе;
- область разделяемой буферной памяти;
- $\mathbb{R}$  IRQ запрос прерывания;

вый драйвер дисковых устройств входит в BIOS хост-адаптера. Расширения, например ASPI (Advanced SCSI Programming Interface), загружаются отдельно. От драйверов сильно зависит производительность устройств SCSI. «Умное» ПО способно эффективно загружать работой устройства, а иногда и «срезать углы» — выполнять копирование данных между

устройствами без выхода на системную шину компьютера.

# 6. Интерфейс АТА

Интерфейс ATA— AT Attachment for Disk Drives — разрабатывался в 1986-1990 гг. для подключения накопителей на жестких магнитных дисках к компьютерам IBM PC AT с шиной ISA. Стандарт, выработанный комитетом X3T10, определяет набор регистров и назначение сигналов 40-контактного интерфейсного разъема. Интерфейс появился в результате переноса контроллера жесткого диска ближе к накопителю. то есть создания устройств со встроенным контроллером — IDE (Integrated Device Electronic). Стандартный для АТ контроллер жесткого диска был перенесен на плату электроники накопителя с сохранением регистровой модели. При этом удлинилась связь с устройством со стороны системной шины, которую непосредственно выводить на длинный ленточный кабель было нецелесообразно. Это сказалось бы на скорости работы шины, надежности и цене. Из всех сигналов шины ISA выбрали минимальный набор сигналов, часть из которых буферизовали на небольшой плате, устанавливаемой в слот, а часть направили прямо на разъем ленточного кабеля нового интерфейса. Из сигналов системной шины потребо-

шина данных — используется полностью;

вались следующие:

- шина адреса 3 младших бита поступают в интерфейс, старшие биты и сигнал AEN проходят через дешифратор, вырабатывающий сигналы выбора устройства CS0# и CS1#:
- шина управления используются сигналы чтения и записи портов и аппаратного сброса, запрос прерывания, пара сигналов канала DMA, сигналы готовности и управления разрядностью передачи.

Поскольку стандартный контроллер АТ позволял подключать до двух накопителей, эту возможность получил и интерфейс АТА. Однако теперь два накопителя стали означать и два контроллера. Их подключили к одной интерфейсной

устройство со встроенным контроллером, которому в пространстве портов ввода/вывода достаточно того же набора регистров и которое способно поддержать режим выбора устройства через вышеупомянутый бит. Принятая система команд и регистров, являющаяся частью спецификации АТА, ориентирована на блочный обмен данными с устройствами прямого доступа. Для иных устройств существует спецификация ATAPI, основанная на тех же аппаратных средствах, но позволяющая обмениваться пакетами управляющей информации ( $PI-Package\ Interface$ ). Пакетный интерфейс позволяет расширить границы применения шины АТА.

шине, а для программной совместимости бит выбора накопителя (DEV) в регистре номера головки и номера устройства (Drive/Head register) стали использовать для выбора устройства. Для взаимодействия пары устройств на шине ввели несколько дополнительных сигналов. Так появился интерфейс ATA для подключения устройств IDE к шине ISA. Позже их стали подключать и к локальным шинам, но набор сигналов интерфейса и протоколы обмена сохранились. Достаточно универсальный набор сигналов позволяет подключать любое

пителей изначально указывали адрес цилиндра (Cylinder), головки (Head) и сектора (Sector) — так называемая *трехмерная адресация СНS*. Позже по ряду причин стали различать физическую (реальную для накопителя) и логическую (по которой с устройством общается программа) адресацию *СНS*. При этом одно и то же устройство могло иметь различную логическую геометрию (но, естественно,  $C \times H \times S_{\pi or} \le C \times H \times S_{\phi ts}$ ). Преобразование логической адресации в физическую выполняется встроенным контроллером

Адресация в ATA тоже имеет «дисковые корни»: для нако-

устройства. Позже пришли к *пинейной адресации погических* блоков LBA (Logical Block Addressing), где адрес блока (сектора) определяется 28-битным числом.

В спецификации ATA фигурируют следующие компоненты: \*\* Хост-адаптер — средства сопряжения интерфейса ATA с системной шиной (набор буферных схем между шинами ISA и ATA). Хостом мы будем называть компьютер с хост-

адаптером интерфейса АТА.

- Кабель-шлейф с двумя или тремя 40-контактными IDCразъемами. В стандартном кабеле одноименные контакты всех разъемов соединяются вместе.
- $\blacksquare$  Ведущее устройство (Master) ПУ, в спецификации АТА официально называемое Device-0 (устройство 0).
- $\blacksquare$  Ведомое устройство (Slave) ПУ, в спецификации официально называемое Device-1 (устройство 1).

циально называемое *Device-1* (устройство 1). Если к шине АТА подключено одно устройство, оно должно быть ведущим. Если подключены два устройства, одно должно быть ведущим, другое — ведомым. О своей роли (ведущее или ведомое) устройства «узнают» с помощью предваритель-

но установленных конфигурационных джамперов. Если применяется «кабельная выборка» (см. ниже), роль устройства определяется его положением на специальном кабеле-шлейфе. Оба устройства воспринимают команды от хост-адаптера одновременно. Однако исполнять команду будет лишь выбран-

пое устройство. Если бит DEV=0, выбрано ведущее устройство, если DEV=1 — ведомое. Выходные сигналы на шину ATA имеет право выводить только выбранное устройство. Такая система подразумевает, что, начав операцию обмена с одним из устройств, хост-адаптер не может переключиться на обслуживание другого до завершения начатой операции. Параллельно могут работать только устройства IDE, подключаемые к разным шинам (каналам) ATA. Спецификация ATA-4 определяет способ обхода этого ограничения (см. 6.6). Выполняемая операция и направление обмена данными между устройством и хост-адаптером определяются предвари-

тельно записанной командой. Непременным компонентом устройства является буферная память. Ее наличие позволяет выполнять обмен данными в темпе, предлагаемом хост-адаптером (в пределах возможности устройства), без оглядки на внутреннюю скорость передачи данных между носителем и

- буферной памятью ПУ. Для подключения устройств IDE существует несколько разновидностей интерфейса:
- АТА, он же AT-BUS 16-битный интерфейс подключения к шине компьютера АТ. Наиболее распространенный

РС Card ATA — 16-битный интерфейс с 68-контактным разъемом РС Card (РСМСІА) для подключения к блокнотным РС.
 ХТ IDE (8-бит), он же ХТ-ВUS — 40-проводный интерфейс, похожий на АТА, но несовместимый с ним.
 МСА IDE (16-бит) — 72-проводный интерфейс, предназ-

наченный специально для шины и накопителей PS/2.

и питание.

40-проводной сигнальный и 4-проводной питающий интерфейс для подключения дисковых накопителей к компьютерам АТ. Для миниатюрных (2,5" и менее) накопителей используют 44-проводной кабель, по которому передается

\* ATA-2 — расширенная спецификация ATA. Включает 2 канала, 4 устройства, PIO Mode 3, multiword DMA mode 1, Block mode, объем диска до 8 Гбайт, поддержка LBA и CHS.

\* Fast ATA-2 разрешает использовать Multiword DMA Mode 2 (13.3 M62) (13.3 M6

Fast A1A-2 разрешает использовать Multiword DMA Mode 2 (13,3 Mбайт/с), PIO Mode 4.

ATA-3 — расширение ATA-2. Включает средства парольной защиты, улучшенного управления питанием, самотестирования с предупреждением приближения отказа —

рования с предупреждением приближения отказа — SMART (Self Monitoring Analysis and Report Technology). *ATA/ATAPI-4* — расширение ATA-3, включающее режим *Ultra DMA* со скоростью обмена до 33 Мбайт/с и пакетный интерфейс ATAPI.

Е-IDE (Enhanced IDE) — расширенный интерфейс, введенный фирмой Western Digital. Реализуется в адаптерах для шин PCI и VLВ. Позволяет подключать до 4 устройств (к двум каналам), включая CD-ROM и стриммеры (ATAPI). Поддерживает PIO Mode 3, multiword DMA mode 1, объем диска до 8 Гбайт, LBA и CHS. С аппаратной точки зрения.

тически полностью соответствует спецификации ATA-2. Устройства ATA IDE, E-IDE, ATA-2, Fast ATA-2, ATA-3 и ATA/ATAPI-4 электрически совместимы. Степень логической совместимости достаточно высока (все базовые возможности

АТА доступны). Однако для полного использования всех расширений необходимо соответствие спецификаций устройств, хост-адаптера и его ПО. В настоящее время наиболее широко

распространен и четко стандартизован интерфейс, официально называемый АТА-2, о котором в основном и пойдет речь.

прорези в бандаже вилки стандартом не приветствуется. Для соединения устройств спецификация требует применения плоского многожильного кабеля (Flat cable stranded 28 AWG) типа 3М 3365-40 или эквивалентного. Возможно применение экранированного кабеля (Flat cable stranded 28 AWG 3M 3517-40 shielded). Длина кабеля не должна превышать 0,46 м (18"), допустимая емкость проводников не более 35 пФ. Терминаторы стандартом не предусматриваются (они имеются в каждом устройстве и хост-адаптере), но если кабель с тремя разъемами (розетками) используют для подключения одного устройства, то и его, и хост-адаптер рекомендуется подключать к противоположным концам кабеля. Состав информационных сигналов интерфейса АТА приведен в табл. 6.1. Все сигналы АТА являются логическими со стандартными ТТЛуровнями. Вид кабеля приведен на рис. 6.1. Одноименные контакты всех разъемов соединяются своими проводами. Встречается (редко) шлейф с кабельной выборкой (рис. 6.2). В нем провод 28 в шлейфе перерезан, так что контакт 28 (CSEL) для ведущего устройства заземлен через хост-адаптер, а для ведомого — не подключен. Кабель должен соответствовать системе адресации, выбранной для обоих устройств. Для устойчивой работы в режиме Ultra DMA рекомендуется применение 80-проводных кабелей, обеспечивающих чередование сигнальных цепей и проводов схемной земли (эти кабели «разделываются» на обычные 40-контактные разъемы). Устройства и адаптеры, рассчитанные на использование Ultra DMA, доджны иметь в сигнальных цепях последовательные согласующие резисторы с сопротивлением для различных цепей 22, 33 или 82 Ом. Спецификация АТА «узаконивает» 40-контактный сигнальный и 4-контактный разъемы питания (рис. 6.36), но для малогабаритных устройств питание может подаваться по 44-проводному интерфейсному кабелю.

Все информационные сигналы интерфейса передаются через 40-контактный разъем, у которого ключом является отсут-

пользование в качестве ключа выступа на корпусе розетки и

ствующий на вилке и закрытый на розетке контакт № 20. Ис-

6.1. Электрический интерфейс



| Сигнал                                      | Тип¹                  | Контакт              | Контакт               | Тип¹               | Сигнал                                          |
|---------------------------------------------|-----------------------|----------------------|-----------------------|--------------------|-------------------------------------------------|
| DD 4                                        | I/O TS                | 9                    | 10                    | I/O TS             | DD 11                                           |
| DD 3                                        | I/O TS                | 11                   | 12                    | I/O TS             | DD 12                                           |
| DD 2                                        | I/O TS                | 13                   | 14                    | I/O TS             | DD 13                                           |
| DD 1                                        | I/O TS                | 15                   | 16                    | I/O TS             | DD 14                                           |
| DD 0                                        | I/O TS                | 17                   | 18                    | I/O TS             | DD 15                                           |
| GND                                         | -                     | 19                   | 20                    | -                  | Ключ<br>(нет штырька)                           |
| DMARQ                                       | O TS <sup>2</sup>     | 21                   | 22                    | _                  | GND                                             |
| DIOW#<br>/STOP <sup>3</sup>                 | I                     | 23                   | 24                    | _                  | GND                                             |
| DIOR#<br>/HDMARDY#<br>/HSTROBE <sup>3</sup> | I                     | 25                   | 26                    |                    | GND                                             |
| IORDY<br>/DDMARDY#<br>/DSTROBE 3            | O TS²                 | 27                   | 28                    | I/O                | SPSYNC/CSEL                                     |
| DMACK#                                      | I                     | 29                   | 30                    | _                  | GND                                             |
| INTRQ                                       | O TS <sup>2</sup>     | 31                   | 32                    | о ок               | IOCS16#                                         |
| DA 1                                        | I                     | 33                   | 34                    | I, O <sup>4</sup>  | PDIAG#                                          |
|                                             |                       |                      |                       |                    | /CBLID <sup>3</sup>                             |
| DA 0                                        | I                     | 35                   | 36                    | I                  | DA 2                                            |
| CS0#                                        | I                     | 37                   | 38                    | I                  | CS1#                                            |
| DASP#                                       | I/O OK⁵               | 39                   | 40                    | _                  | GND                                             |
| +5 B (Logic)                                | _                     | 41 <sup>6</sup>      | 42 <sup>6</sup>       | -                  | +5 B (Motor)                                    |
| GND                                         | 1                     | 43 <sup>6</sup>      | 44 <sup>6</sup>       | -                  | Зарезервирован                                  |
| ленный, TS — <sup>2</sup> У старых устр     | тристаби.<br>ойств си | льный, О<br>гнал мож | С — откр<br>сет иметь | ытый кол<br>тип ОС | I/O — двунаправ-<br>лектор.<br>(при разнотипных |
| сигналах на од                              |                       |                      | _                     | -                  |                                                 |
| <sup>3</sup> Сигналы, прив<br>Ultra DMA (A  |                       | юсле сим             | вола /, ис            | пользуют           | ся только в режиме                              |
| 4 У ведущего уст                            | гройства              | — вход, у            | ведомого              | — выход            |                                                 |
| 5 У ведомого уст                            | гройства              | — только             | выход.                |                    |                                                 |
| <sup>6</sup> Контакты 41-                   | 44 исполі             | зуются т             | олько для             | и миниатк          | рных дисков.                                    |

RESET# (Device reset) — сброс устройства (инвертированный сигнал сброса системной шины). Сигнал длительностью не менее 25 мкс вырабатывается после установления питающих напряжений. DA[2:0] (Device Address) — три младших бита системной

В документации на устройства могут применяться несколько отличающиеся обозначения сигналов. Здесь приведены обозначения из стандарта АТА/АТАРІ-4. Сигналы имеют

следующее назначение:

шины адреса, используемые для выбора регистров устройств. DD[15:0] (Device Data) — двунаправленная 16-битная шина данных между адаптером и устройствами. При 8-битных обменах используются младшие биты D[7:0].

DIOR# (Device I/O Read) — строб чтения портов ввода/вывода. Данные фиксируются по положительному перепаду

сигнала. DIOW# (Device I/O Write) — строб записи портов ввода/вывода. Данные фиксируются по положительному перепаду сигнала.

IORDY (I/O channel ready) — готовность устройства завершить цикл обмена. Низким уровнем сигнала во время цикла обмена устройство может ввести такты ожидания шины. Сигнал требуется при обмене в PIO MODE 3 и выше.

IOCS16# — разрешение 16-битных операций. Обращение ко

всем регистрам, кроме регистра данных, всегда 8-битное. Для PIO MODE 0, 1, 2 при активном сигнале обращения 16-битные, при неактивном — 8-битные. Для PIO MODE 3, 4 и DMA все обмены 16-битные, кроме дополнительных байт

(выходящих за границу 512-байтного сектора) «длинного» считывания и записи.

DMARQ (DMA ReQuest) — запрос обмена по каналу DMA (сигнал необязательный). При разрешении обмена сигнал (высокий уровень) вводится устройством по готовности к обмену.

Введя сигнал DMARQ, устройство должно дождаться подтверждения от хост-адаптера сигналом DMACK#, после чего может снять запрос DMARQ. Для очередной передачи запрос дол-

жен быть введен снова. В режиме Multi-Word DMA запрос может

может быть только у выбранного устройства во время работы с DMA. В АТА-1 для этого сигнала мог использоваться как тристабильный, так и стандартный ТТЛ-выход. Работа на одной шине устройств с разнотипными выходами DMARQ может привести к конфликтам.

DMACK# (DMA aCKnowledge) — подтверждение DMA. Сиг-

удерживаться на время передачи всех данных. Выход должен быть тристабильным, в активном состоянии (0 или 1) он

нал вырабатывается хост-адаптером как подтверждение цикла передачи. Передача слова данных управляется сигналами DIOR# или DIOW#. Во время обмена по каналу DMA сигналы IOCS16#, CSO# и CS1# не используются, обмен всегда производится 16-битными словами.

INTRQ (Device interrupt) — запрос прерывания. Выход должен быть тристабильным, активный сигнал (логическую 1) вырабатывает только выбранное устройство, когда у него имеется необслуженный запрос прерывания и его вырабатывание не запрещено битом nIEN в регистре Device Control. Запрос сбрасывается по сигналу RESET#, установке бита SRST в регистре Device Control, записи в регистр команд или чтении регистра состояния. При обменах PIO запрос устанавливается в начале передачи каждого блока (сектора или группы секторав при многосекторных операциях). Исключения: по командам Format Track, Write Sector(S), Write

Запрос сбрасывается по сигналу RESET#, установке бита SRST в регистре Device Control, записи в регистр команд или чтении регистра состояния. При обменах PIO запрос устанавливается в начале передачи каждого блока (сектора или группы секторов при многосекторных операциях). Исключения: по командам Format Track, Write Sector(S), Write Buffer и Write Long в начале передачи первого блока данных запрос прерывания не вырабатывается. При обменах DMA запрос прерывания вырабатывается только по завершении операции.

СSO# (Chip Select 0) — сигнал выбора блока командных регистров (Command Block Registers). Для первого канала он вырабатывается при наличии на системной шине адреса порта ввода/вывода в диапазоне 1F0h-1F7h (сигнал также на-

зывают CS1FX#).

CS1# (Chip Select 1) — выбор блока управляющих регистров (Control Block Registers). Для первого канала он вырабатывается при наличии на системной шине адреса порта ввода/вывода в диапазоне 3F6h-3F7h (часто этот сигнал на-

зывается CS3FX#).

щее устройство отмечает этот факт установкой бита 7 регистра ошибок. Если ведомое устройство не обнаружено, ведущее обнуляет регистр состояния ведомого устройства и сообщает свое состояние сразу после завершения собственной самодиагностики. Сигнал служит только для связи двух устройств и хост-адаптером не используется (в АТА-4 контакт задействован для сигнала CBLID#).

СВЫО# (Cable assembly type identifier) — идентификация типа

кабеля. В 80-проводной сборке контакт 34 на разъеме хостадаптера соединяется с шиной GND, а контакты 34 разъемов устройств соединяются между собой, но связи с разъемом

PDIAG# (Passed diagnostics) — сигнал о прохождении диагностики. Ведущее устройство наблюдает за этим сигналом, который ведомое устройство должно выработать в ответ на сброс или команду диагностики. Если ведомое устройство обнаружено (по сигналу DASP#), ведущее устройство ожидает сигнал в течение 31 с после сброса и 6 с после команды диагностики. Если за это время сигнал не появился, веду-

хост-адаптера не имеют. После прохождения сброса (когда сигнал PDIAG# снимается) хост может определить наличие 80-проводного кабеля по низкому уровню сигнала. DASP# (Device Active, Slave Present) — сигнал двойного назначения: индикатор активности устройства и присутствия ведомого устройства. Устройства имеют выход типа «открытый коллектор» с нагрузочным резистором 10 кОм к шине +5 В. После сброса по сигналу RESET# или при инипиали-

тый коллектор» с нагрузочным резистором 10 кОм к шине +5 В. После сброса по сигналу RESET# или при инициализации по включении питания оба устройства в течение 1 мс должны деактивировать этот сигнал, после чего не позже чем через 400 мс его вводит ведомое устройство для сообщения о своем присутствии. Ведущее устройство не активирует этот сигнал в течение 450 мс. Сигнал деактивируется ведомым устройством после получения им команды или через 31 с автоматически (смотря что произойдет раньше). После этого сигнал может быть введен любым устройством как инди-

катор активности. Адаптер использует этот сигнал для включения светодиодного индикатора доступа к диску. SPSYNC/CSEL (Spindle Synchronization/Cable Select) — синхронизация шпинделя/выборка кабелем. Сигнал двойного

мами двух устройств (малораспространенная «кабельная выборка»). Эта линия на хост-адаптере заземлена, и ведущее устройство получает заземленную линию, а ведомое—не подключенную. Состояние сигнала (если он управляется хост-адаптером) должно удерживаться по крайней мере 31 с после сигнала RESET#.

назначения, которое должно быть единым для обоих устройств. Сигнал SPSYNC позволяет синхронизировать шпиндели устройств (актуально для RAID-массивов); используется по усмотрению производителя накопителя. Сигнал CSEL позволяет устройствам определять свой адрес по положению на специальном кабеле с разрывом провода 28 между разъе-

чают новое назначение сигналов:

STOP (Stop Ultra DMA burst) — останов передачи пакета Ultra DMA.

DDMARDY# (Device Ultra DMA ready) — готовность устройства при приеме пакета Ultra DMA (управление по-

При использовании режима *Ultra DMA* четыре линии полу-

- током).

  DSTROBE (Host Ultra DMA data strobe) строб данных устройства при передаче пакета хосту. Данные переда-
- ются по обоим перепадам DSTROBE.

  НDMARDY# (Host Ultra DMA ready) готовность хоста при приеме им пакета Ultra DMA (управление по-
- та при приеме им пакета Ultra DMA (управление потоком).

   HSTROBE (Host Ultra DMA data strobe) строб данных
- HSTROBE (Host Ultra DMA data strobe) строб данных хоста при передаче пакета устройству. Данные передаются по обоим перепадам HSTROBE.

Для компьютеров класса XT существует 8-битная версия интерфейса, называемая XT-IDE, реже — XT-Bus. Этот интерфейс (табл. 6.2), как и ATA, реализован на 40-проводном

кабеле, и многие его сигналы совпадают с 16-битной шиной ATA. Интерфейс XT-IDE можно рассматривать как подмножество ATA, хотя прямой совместимости нет. Ряд устройств ATA имеют джампер выбора режима XT/AT (в накопите-

ATA имеют джампер выбора режима XT/AT (в накопителях Seagate на это указывает окончание AX в обозначении модели).

| Таблица 6.2. Кабель интерфейся XT IDE |                   |         |         |                       |  |  |  |
|---------------------------------------|-------------------|---------|---------|-----------------------|--|--|--|
| Сигнал                                | Tun¹              | Контакт | Контакт | Сигнал                |  |  |  |
| RESET#                                | I                 | 1       | 2       | GND                   |  |  |  |
| DD 7                                  | I/O TS            | 3       | 4       | GND                   |  |  |  |
| DD 6                                  | I/O TS            | 5       | 6       | GND                   |  |  |  |
| DD 5                                  | I/O TS            | 7       | 8       | GND                   |  |  |  |
| DD 4                                  | I/O TS            | 9       | 10      | GND                   |  |  |  |
| DD 3                                  | I/O TS            | 11      | 12      | GND                   |  |  |  |
| DD 2                                  | I/O TS            | 13      | 14      | GND                   |  |  |  |
| DD 1                                  | I/O TS            | 15      | 16      | GND                   |  |  |  |
| DD 0                                  | I/O TS            | 17      | 18      | GND                   |  |  |  |
| GND                                   | -                 | 19      | 20      | Ключ<br>(нет штырька) |  |  |  |
| AEN                                   | I                 | 21      | 22      | GND                   |  |  |  |
| DIOW#                                 | I                 | 23      | 24      | GND                   |  |  |  |
| DIOR#                                 | I                 | 25      | 26      | GND                   |  |  |  |
| DMACK#                                | I                 | 27      | 28      | GND                   |  |  |  |
| DMARQ                                 | оос               | 29      | 30      | GND                   |  |  |  |
| INTRQ                                 | O TS <sup>2</sup> | 31      | 32      | GND                   |  |  |  |
| DA 1                                  | I                 | 33      | 34      | GND                   |  |  |  |
| DA 0                                  | I                 | 35      | 36      | GND                   |  |  |  |
| CS0#                                  | I                 | 37      | 38      | GND                   |  |  |  |

40

GND

39

DASP#

## 6.2. Регистры устройств

Каждое устройство АТА имеет стандартный набор регистров, адресуемых сигналами от хост-адаптера (CSO#, CS1#, DA2, DA1, DA0, DIOR# и DIOW#). Набор регистров (табл. 6.3)

 $<sup>^{1}</sup>$  Тип сигнала для устройства: I — вход, О — выход, I/O — двунаправленный, TS — тристабильный, OC — открытый коллектор.

<sup>2</sup> У старых устройств сигнал может иметь тип ОС (при разнотипных сигналах на одной шине возможен конфликт).

<sup>&</sup>lt;sup>3</sup> У ведомого устройства — только выход.

Блок командных регистров служит для посылки команд устройству и чтения информации о его состоянии. Блок управляющих регистров используется для управления устройством и получения более подробной информации о его состоянии. На действительность содержимого регистров командного блока и альтернативного регистра состояния указывает нулевое значение бита BSY регистра состояния. Если устройство поддерживает управление энергопотреблением, в «спящем» режиме содержимое этих регистров недействительно. Таблица: 6.3. Регистры контроллеров устройств АТА Адрес Назначение (R — чтение, W — запись) CSO# CS1# DA2 DA1

состоит из двух блоков, выбираемых сигналом CS0#/CS1#.

| 1     | 1        | х        | х        | х      | Не используется<br>(шина данных в третьем<br>состоянии)                                                             |
|-------|----------|----------|----------|--------|---------------------------------------------------------------------------------------------------------------------|
| Contr | ol Block | Register | s — бло  | к упра | вляющих регистров                                                                                                   |
| 1     | 0        | 0        | х        | х      | Не используется (шина данных<br>в третьем состоянии)                                                                |
| 1     | 0        | 1        | 0        | х      | Не используется (шина данных в третьем состоянии)                                                                   |
| 1     | 0        | 1        | 1        | 0      | R: Alternate Status (AS) — альтернативный регистр состояния W: Device Control (DC) — регистр управления устройством |
| 1     | 0        | 1        | 1        | 1      | Не используется <sup>1</sup>                                                                                        |
| Comn  | and Blo  | ck Regis | ters — 6 | лок ко | мандных регистров                                                                                                   |
| 0     | 1        | 0        | 0        | 0      | R/W: <i>Data</i> ( <i>DR</i> ) — регистр<br>данных                                                                  |
| 0     | 1        | 0        | 0        | 1      | R: Error (ER) — регистр ошибок<br>W: Features (FR) — регистр свойств                                                |
| 0     | 1        | 0        | 1        | 0      | R/W: Sector Count (SC) — регистр счетчика секторов                                                                  |
| 0     | 1        | 0        | 1        | 1      | R/W: Sector Number (SN) —<br>регистр номера сектора LBA<br>[7:0] <sup>2</sup>                                       |

#### Таблица 6.3 (продолжение)

| Адрес                                              |   |   |   |   | Назначение<br>(R — чтение, W — запись)                                                       |  |  |  |  |  |
|----------------------------------------------------|---|---|---|---|----------------------------------------------------------------------------------------------|--|--|--|--|--|
| CSO# CS1# DA2 DA1 DA0                              |   |   |   |   | 1                                                                                            |  |  |  |  |  |
| Command Block Registers — блок командных регистров |   |   |   |   |                                                                                              |  |  |  |  |  |
| 0                                                  | 1 | 1 | 0 | 0 | R/W: Cylinder Low (CL) — регистр<br>младшего байта номера цилиндра<br>LBA[15:8] <sup>2</sup> |  |  |  |  |  |
| 0                                                  | 1 | 1 | 0 | 1 | R/W: Cylinder High (CH) — регистр старшего байта номера цилиндра LBA[23:16]2                 |  |  |  |  |  |
| 0                                                  | 1 | 1 | 1 | 0 | R/W: Device/Head (DH) — регистр<br>номера устройства<br>и головки LBA[27:24] <sup>2</sup>    |  |  |  |  |  |
| 0                                                  | 1 | 1 | 1 | 1 | R: Status (SR) — регистр состояния W: Command (CR) — регистр команд                          |  |  |  |  |  |
| 0                                                  | 0 | х | х | х | Недопустимый адрес                                                                           |  |  |  |  |  |

по этому адресу устройство не отвечало. Если устройство отвечает, то оно не должно управлять битом DD7 во избежание конфликта с контроллером НГМД.

<sup>2</sup> Регистры сектора, цилиндра и головки в режиме LBA содержат ука-

### Назначение бит регистра SR:

занные биты логического адреса.

Бит 7 — BSY (Busy) указывает на занятость устройства. При BSY=1 устройство игнорирует попытки записи в командный блок регистров, а чтение этих регистров дает неопре-

деленный результат. При BSY=0 регистры командного блока доступны, а устройство может изменять только значение бит IDX, DRDY, DF, DSC и CORR. Бит устанавливается при аппаратном/программном сбросе устройства и по получении команды. Бит может устанавливаться на кратковременный интервал, так что хост может этого не заметить.

Регистр состояния SR отражает текущее состояние устройства в процессе выполнения команд. Чтение регистра состояния разрешает дальнейшее изменение его бит и сбрасывает запрос аппаратного прерывания.

стояние бита изменилось, оно не может измениться обратно до чтения регистра состояния. При DRDY=0 устройство воспринимает только команды Execute Device Diagnostic и Initialize Device Parameters, прекращая выполнение текущей команды и сообщая об этом флагом ABRT

в регистре ошибок и *ERR* в регистре состояния. Другие команды приводят к непредсказуемым результатам.

Бит 6 — DRDY (Device Ready) указывает на готовность устройства к восприятию любых кодов команд. Если со-

Бит 5 — DF (Device Fault) — индикатор отказа устройства. Бит 4 — DSC (Device Seek Complete) — индикатор завершения поиска трека. В командах, допускающих перекры-

тие (см. 6.6), бит называется SERV (Service Required) — устройство требует обслуживания.

Бит 3 — DRQ (Data Request) — индикатор готовности к обмену словом или байтом данных.

Бит 2 — CORR (Corrected Data) — индикатор исправленной опроводительного простои в применентых применентых.

ной ошибки данных.

Бит 1 — *IDX* (*InDeX*) — индекс, трактуется особо каждым производителем.

Бит 0 — *ERR* (*Error*) — индикатор ошибки выполнения предыдущей операции. Дополнительная информация содер-

Бит 0 — ERR (Error) — индикатор ошибки выполнения предыдущей операции. Дополнительная информация содержится в регистре ошибок. Если установлен бит ERR, до приема следующей команды, программного или аппаратного сброса устройство не изменит состояние этого бита, а также регистра ошибок, регистра количества секторов и регистров цилиндра, головки и номера сектора.

В стандарте ATA-4 для некоторых команд биты 4 и 5 могут

а также регистра ошибок, регистра количества секторов и регистров цилиндра, головки и номера сектора. В стандарте ATA-4 для некоторых команд биты 4 и 5 могут иметь иное назначение, а биты 1 и 2 объявлены устаревшими. Альтернативный регистр состояния AS имеет те же биты, что и основной, но его чтение не приводит ни к каким изменениям состояния устройства.

нениям состояния устройства.

Назначение регистра команд СВ очевидно из названия. Устройство начинает исполнять команду сразу, как только ее код записан в данный регистр.

код записан в данный регистр.

Регистры номера цилиндра (старшего СН и младшего байта СС) и номера сектора SN имеют двоякое назначение в зависимости от выбранной системы адресации (СНЅ или LBA).

Они инициализируются хост-адаптером, а в случае возникновения ошибки при операции устройство поместит в них адрес, по которому встретилась ошибка.

Регистр номера устройства и головки DH кроме хранения

части адресной информации служит для выбора ведущего или ведомого устройства и метода адресации.

Назначение бит регистра DH:

- - та используется режим СНS.

    Бит 4 DEV (Device) выбор устройства. При DEV=0 выбрано ведущее, при DEV=1 ведомое.
- ™ Биты [3:0] имеют двоякое назначение в зависимости от выбранной системы адресации. В режиме CHS они содержат номер головки, в режиме LBA старшие биты логического адреса. Как и предыдущие, этот адресный регистр инициализируется хост-адаптером, а в случае возникновения ошибки при операции устройство поместит в них адрес, по которому встретилась ошибка.
- До принятия ATA-2 считалось, что адресные регистры должны модифицироваться и после успешного выполнения операции, отражая текущее значение адреса в носителе. После включения питания, сброса или выполнения диагностики устройство в блоке командных регистров содержит
- *сигнатуру*, определяющую его тип:

  SC=01h, SN=01h, CL=00h, CH=00h, DH=00h устройства ATA:
- SC=01h, SN=01h, CL=14h, CH=EBh, DH=00h или 01h устройства ATAPI.

Регистр данных DR может использоваться как 8-битный

- или 16-битный в зависимости от типа данных, передаваемых в текущей команде.

  Из регистра управления устройством СР используются толь-
- из регистра управления устроиством Сн используются только два бита.
- **Назначение бит регистра** *CR*:
  - 🛚 Биты [7:3] зарезервированы.

Бит 2 — SRST (Software Reset) — программный сброс, действует все время, пока бит не будет снят. Оба устройства на шине воспринимают программный сброс одновре-

Бит 1 - nIEN (Interrupt Enable) — инверсный бит разреше-

менно. На устройства АТАРІ не действует.

- - Бит 6 UNC (Uncorrectable Data Error) неисправимая ошибка данных.
  - Бит 5 *MC (Media Changed)* смена носителя. После смены носителя первая команда обращения отвергается и устанавливается данный бит. После сброса бита следу-
  - и устанавливается данный бит. После сброса бита следующие команды будут выполняться нормальным образом.

    Бит 4 *IDNF (ID Not Found)* указывает на ненайденный идентификатор сектора.
  - Бит 3 ABRT (Aborted Command) устанавливается, если команда отвергнута как недействительная или в случае возникновения иной ошибки.
- Бит 2 MCR (Media Change Requested) индикатор запроса смены носителя. После обнаружения запроса смены носителя следующие команды Door Lock будут возвращать бит ошибки ERR и установленный бит MCR. Бит
- MCR сбрасывается командами Door Unlock, Media Eject или аппаратным сбросом.

  Бит 1 TKONE (Track O Not Found) указывает на то ито
- Бит 1 *TKONF (Track 0 Not Found)* указывает на то, что по команде *Recalibrate* не удалось найти нулевой трек.
- Бит 0 *AMNF (Address Mark Not Found)* не найден адресный маркер данных в заголовке сектора.

Diagnostic регистр ошибок содержит диагностический код.

Регистр свойств FR используется в зависимости от команды. В команде Set Features через него задается код подкоманды. Некоторые устройства могут игнорировать запись в этот регистр.

После включения питания, сброса или команды Execute Device

До принятия ATA-2 в этот регистр помещали значение рекомендуемого номера цилиндра для предкомпенсации записи. Регистр счетчика секторов SC содержит число секторов, участвующих в обмене. Хост инициализирует этот регистр до

ствующих в обмене. Хост инициализирует этот регистр до подачи команды (нулевое значение соответствует 256 секторам). По успешному завершению операции доступа к данным регистр должен обнулиться. Если команда завершилась с ошибкой, в регистре будет число секторов, которые должны быть переданы для успешного завершения предыдущего запроса. Команды *Initialize Device Parameters* или *Write Same* могут переопределить значение этого регистра.

### 6.3. Система команд

Стандарт АТА задает *систему команд*, ориентированную на накопители на магнитных дисках. В табл. 6.4 графа «Протокол» определяет протокол передачи данных, требуемых для команды (см. 6.5): *PI* — ввод данных от устройства в режиме PIO, *PO* — вывод данных в устройство в режиме PIO, *P* — про-

токол передачи командного пакета (16 байт вывода в режиме

PIO), *DM* — обмен данными по каналу DMA, *DMQ* — обмен DMA с очередями, *ND* — нет обмена данными, *DR* — протокол сброса, *VS* — специфично для устройства. Графа «Тип» определяет характеристику команды: *O* — обязательная для всех устройств, *П* — обязательная для ATAPI, *Д* — дополнительная, *C* —

ройств, П — обязательная для ATAPI, Д — дополнительная, С — специфическая. Графа «Код» содержит шестнадцатеричный код, загружаемый в регистр команды. Коды, помеченные звездочкой, поддерживаются для совместимости со старым ПО. В графе «Использование регистров» приняты следующие обо-

значения: *CY* — регистры цилиндров, *SC* — регистр счетчика секторов, *DH* — регистр номера устройства и головки, *SN* — регистр номера сектора, *FR* — регистр свойств. Назначение регистров: у — регистр содержит параметры для команды (для

регистра номера устройства и головки используются оба пара-

метра), D — используется только номер устройства, d — задействован только номер устройства, использование поля номера головки специфично для производителя, D0 — команда адресуется к ведущему устройству, но выполняют ее оба устройства.

| Команла              | Протокол   | Tun | Кол | Использование регистров |
|----------------------|------------|-----|-----|-------------------------|
| Таблица 6.4. Система | команд АТ/ | 1   |     |                         |

| Команда                                                                                                                       | Протокол        | Тип | Код        | Использование регистров |    |    |    |    |
|-------------------------------------------------------------------------------------------------------------------------------|-----------------|-----|------------|-------------------------|----|----|----|----|
|                                                                                                                               |                 |     |            | FR                      | sc | SN | CY | DH |
| Acknowledge Media<br>Change —<br>подтверждение<br>смены носителя <sup>1</sup>                                                 | VS              | Д   | DBh        |                         | -  | _  | _  | D  |
| Boot — Post-Boot — резерв для сменных носителей 1                                                                             | VS              | Д   | DCh        | -                       | -  | _  | _  | D  |
| Boot — Pre-Boot —<br>резерв для сменных<br>носителей <sup>1</sup>                                                             | VS              | Д   | DDh        | -                       | _  | _  | _  | D  |
| CFA Erase Sectors —<br>стирание секторов <sup>2</sup>                                                                         | ND              | С   | C0h        |                         | у  | у  | у  | у  |
| CFA Request<br>Extended Error<br>Code — чтение<br>расширенного кода<br>ошибки <sup>2</sup>                                    | ND              | С   | 03h        | _                       | у  | у  | у  | D  |
| CFA Translate<br>Sector — получение<br>информации<br>о состоянии сектора <sup>2</sup>                                         | PI              | С   | 87h        |                         |    | У  | у  | у  |
| CFA Write Multiple Without Erase — множественная запись без операции стирания (в предварительно стертые секторы) <sup>2</sup> | PO              | С   | CDh        |                         | У  | у  | у  | у  |
| Check Power<br>Mode — проверка<br>режима<br>энергопотребления                                                                 | ND <sub>.</sub> | Д   | 98h<br>E5h | _                       | у  |    | -  | D  |
| Door Lock — запретить смену посителя <sup>3</sup>                                                                             | vs              | Д   | DEh        | -                       | _  | -  | _  | D  |

| Таблица 6.4 (продолж                                                                                      | ение)    |     |     |       |       |      |       |      |
|-----------------------------------------------------------------------------------------------------------|----------|-----|-----|-------|-------|------|-------|------|
| Команда                                                                                                   | Протокол | Тип | Код | Испо  | льзов | ание | регис | тров |
|                                                                                                           |          |     | 1   | FR    | SC    | SN   | CY    | DH   |
| Door Unlock — разрешить смену носителя <sup>3</sup>                                                       | VS       | Д   | DFh | _     | -     | -    | _     | D    |
| Device Reset — сброс<br>устройства ATAPI <sup>2</sup>                                                     | DR       | П   | 08h | -     | -     | _    | -     | D    |
| Download  Microcode — загрузка микрокода внутреннего ПО <sup>4</sup>                                      | РО       | Д   | 92h | у     | у     | у    | у     | D    |
| Execute Device<br>Diagnostic —<br>диагностика                                                             | ND       | 0   | 90h | -<br> | _     | _    | _     | D08  |
| Flush Cache— выгрузка кэша записи на носитель (время выполнения может достигать 30 с) <sup>2</sup>        | ND       | Д   | E7h |       | _     | -    | _     | D    |
| Format Track — форматирование трека <sup>3</sup>                                                          | VS       | С   | 50h | _     | _     | _    | _     | D8   |
| Get Media Status — получение информации о состоянии носителя (наличие, смена, защита записи) <sup>2</sup> | ND       | Д   | DAh |       | _     | _    |       | D    |
| Identify Device — идентификация устройства (не пакетного)                                                 | PI       | 0   | Ech | -     | -     | _    | _     | D    |
| Identify Device DMA — идентификация устройства с ответом в режиме DMA <sup>5</sup>                        | DM       | Д   | EEh | _     | _     |      |       | D    |
| Identify Packet Device — идентифи- кация устройства (пакетного) <sup>2</sup>                              | PI       | П   | A1h |       |       |      |       | D    |

| Команда                                                                                                      | Протокол | Тип | Код        | Испо | Использование регистров |    |    |    |  |  |
|--------------------------------------------------------------------------------------------------------------|----------|-----|------------|------|-------------------------|----|----|----|--|--|
|                                                                                                              |          |     | 1          | FR   | SC                      | SN | CY | DH |  |  |
| Idle — переход в со-<br>стояние ожидания                                                                     | ND       | Д   | 97h<br>E3h | -    | у                       | -  | _  | D  |  |  |
| Idle Immediate—<br>немедленный<br>переход в состояние<br>ожидания                                            | ND       | Д   | 95h<br>E1h | _    | _                       | _  | -  | D  |  |  |
| Initialize Device Parameters — инициализация параметров устройства                                           | ND       | 0   | 91h        | _    | у                       | -  | _  | у  |  |  |
| Media Eject — извлечь носитель <sup>4</sup>                                                                  | ND       | Д   | EDh        | _    | -                       | _  | -  | D  |  |  |
| <b>Media Lock</b> — заблокировать носитель (не ATAPI) <sup>2</sup>                                           | ND       | Д   | DEh        | _    | _                       |    | _  | D  |  |  |
| Месіа Unlock — разблокировать носитель (не ATAPI) <sup>2</sup>                                               | ND       | Д   | DFh        | _    | _                       |    |    | D  |  |  |
| <b>Nop</b> — холостая команда                                                                                | ND       | Д   | 00h        | _    | -                       |    | -  | у  |  |  |
| Раскет — посылка командного пакета <sup>2</sup>                                                              | P        | Π   | A0h        | у    | у                       | у  | у  | D  |  |  |
| Read Buffer —<br>чтепие буфера                                                                               | PΙ       | Д   | E4h        | _    | -                       | _  | -  | D  |  |  |
| Read DMA<br>(w/retry) — чтение<br>по DMA с повторами                                                         | DM       | Д   | C8h        |      | у                       | у  | у  | у  |  |  |
| Read DMA (w/o<br>retry) — чтение по<br>DMA без повторов                                                      | DM       | Д   | C9h        | _    | у                       | у  | у  | у  |  |  |
| Read DMA Queued — чтение по DMA с возможностью постановки команды в очередь и освобождения шины <sup>2</sup> | DMQ      | Д   | C7h        | у    | y <sup>8</sup>          | у  | у  | у  |  |  |

Таблица 6.4 (продолжение) Протокол Тип Код Использование регистров Команда SN CY FR SC DH ΡĮ Д 22h y y Read Long y (w/retry) -«длинное» чтение с повторами3 Read Long (w/o ы Д 23h y y у у retry) - «длинное» чтение без повторов<sup>3</sup> C4h ΡĮ Д y у у у Read Multiple множественное чтение F8h Read Native ND Д D Address — чтение максимального адреса сектора (заводской установки)2 Read Sector(s) ы O 20h y y y у (w/retrv) - чтение секторов с повторами 21h Read Sector(s) ΡĮ O y y у у (w/o retry) — чтение секторов без повторов Read Verify ND O 40h y у y y Sector(s) (w/retry) верификационное чтение секторов с повторами ND O 41h Read Verify y у у у Sector(s) (w/o retry) верификационное чтение секторов без повторов Д 1xh D Recalibrate -ND рекалибровка (поиск нулевого трека)<sup>3</sup> Security Disable PO Д F6h D Password — отмена

защиты (с посылкой

пароля)6

| Команда                                                                           | Протокол     | Тип | Код        | Испо | льзов          | ание           | реги           | тров |
|-----------------------------------------------------------------------------------|--------------|-----|------------|------|----------------|----------------|----------------|------|
|                                                                                   |              |     |            | FR   | sc             | SN             | CY             | DH   |
| Security Erase Prepare— подготовка к защит- ному стиранию <sup>6</sup>            | ND           | Д   | F3h        | _    | _              | -              | _              | D    |
| Security Erase Unit — защитное стирание (с посылкой пароля) <sup>6</sup>          | PO           | Д   | F4h        | -    |                | -              | _              | D    |
| Security Freeze<br>Lock — блокировка<br>команд защиты <sup>6</sup>                | ND           | Д   | F5h        | _    | _              | _              | _              | D    |
| Security Set<br>Password — установ-<br>ка пароля защиты <sup>6</sup>              | РО           | Д   | F1h        | _    | -              | _              | -              | D    |
| Security Unlock — снятие защиты <sup>6</sup>                                      | PO           | Д   | F1h        | -    | -              | 1              | -              | D    |
| Seek — поиск                                                                      | ND           | 0   | 7xh        | 1    | -              | у              | у              | у    |
| Service — передача данных и/или состояния команды, освободившей шину <sup>2</sup> | P или<br>DMQ | Д   | A2h        | -    | -              | _              | 1              | D    |
| Set Features —<br>установка свойств                                               | ND           | Д   | Efh        | у    | -              | _              | _              | D    |
| Set Max Address —<br>установка макси-<br>мального адреса <sup>2</sup>             | ND           | Д   | F9h        | _    | y <sup>8</sup> | у              | у              | у    |
| Set Multiple Mode —<br>установка множест-<br>венного режима                       | ND           | Д   | C6h        | 1    | у              | -              | -              | D    |
| Sleep — перевод<br>в «спящий» режим                                               | ND           | Д   | 99h<br>E6h | -    | _              | +              | -              | D    |
| SMART — группа<br>команд мониторинга <sup>6</sup>                                 | ND, PI       | Д   | B0h        | у    | y <sup>8</sup> | y <sup>8</sup> | y <sup>8</sup> | D    |
| Standby — перевод в дежурный режим                                                | ND           | Д   | 96h<br>E2h | _    | у              | -              | _              | D    |
| Standby<br>Immediate — немед-<br>ленный перевод<br>в дежурный режим               | ND           | Д   | 94h<br>E0h | -    |                | -              | _              | D    |

Таблица 6.4 (продолжение)

| Команда                                                                                                         | Протокол | Тип | Код              | Использование регистров |                |    |    |    |  |
|-----------------------------------------------------------------------------------------------------------------|----------|-----|------------------|-------------------------|----------------|----|----|----|--|
|                                                                                                                 |          |     |                  | FR                      | sc             | SN | СУ | DH |  |
| Write Buffer —<br>запись в буфер                                                                                | РО       | Д   | E8h              |                         |                | _  | _  | D  |  |
| Write DMA<br>(w/retry) — запись<br>по DMA с повторами                                                           | DM       | Д   | CAh              | -                       | у              | у  | у  | у  |  |
| Write DMA<br>(w/o retry) — запись<br>по DMA без повторов                                                        | DM       | Д   | CBh              | _                       | у              | у  | у  | у  |  |
| Write DMA Queued — запись по DMA с возмож- ностью постановки команды в очередь и освобождения шины <sup>2</sup> | DMQ      | Д   | CCh              | у                       | y <sup>8</sup> | У  | у  | у  |  |
| Write Long<br>(w/retry) —<br>«длинная» запись<br>с повторами <sup>3</sup>                                       | PO       | Д   | 32h <sup>7</sup> | _                       | у              | у  | у  | у  |  |
| Write Long<br>(w/o retry)<br>«длинная» запись<br>без повторов <sup>3</sup>                                      | PO       | Д   | 33h <sup>7</sup> | _                       | у              | у  | у  | у  |  |
| Write Multiple — множественная запись                                                                           | PO       | Д   | C5h <sup>7</sup> | _                       | у              | у  | у  | у  |  |
| Write Same — запись с размножением                                                                              | PO       | Д   | E9h              | у                       | у              | у  | У  | у  |  |
| Write Sector(s)<br>(with retry) — запись<br>секторов с повторами                                                | PO       | О   | 30h <sup>7</sup> | _                       | у              | у  | у  | у  |  |
| Write Sector(s)<br>(without retry) —<br>запись секторов<br>без повторов                                         | РО       | О   | 31h <sup>7</sup> | _                       | у              | у  | у  | у  |  |
| Write Verify — запись<br>с верификацией                                                                         | PO       | Д   | 3Ch <sup>7</sup> | -                       | у              | у  | у  | у  |  |

<sup>&</sup>lt;sup>2</sup> Только для АТА-4.

- <sup>3</sup> В АТА-4 команда не определена. 4 Для АТА-2 и выше.
- 5 Только для АТА-3.
- <sup>6</sup> Для АТА-3 и выше. 7 Коды поддерживаются для совместимости.
- <sup>8</sup> Использование регистра зависит от производителя.

# 6.3.1. Основные команды

К этой группе относятся команды АТА для доступа к данным. Для устройств, существенно отличающихся от НЖМД, имеется альтернативный способ доставки команд и парамет-

ров — команда *Packet*. По этой команде, используя вывод в режиме PIO, хост-адаптер передает пакет с блоком дескриптора команды. Подробнее о пакетном интерфейсе см. в 6.7.

Минимальной адресуемой единицей команд чтения и записи является 512-байтный сектор.

Команды чтения секторов в режимах обмена PIO - Read Sector(s) и DMA - Read DMA позволяют считывать после-

довательно расположенные секторы, количество которых за-

дано в регистре SC, а адрес начального сектора — в регистрах CH, CL, DH и SN. Команды чтения бывают с повторами или без них. В первом случае, если при чтении сектора об-

наружена неисправимая ошибка, устройство автоматически делает несколько повторных попыток чтения. После исполнения команды в случае неисправимой ошибки блок командных регистров содержит адрес сектора с ошибкой. Если устройство использует ЕСС-код, то некоторые ошибки чтения

оно исправляет без повторов, но указывает на этот факт в регистре ошибок. Команда чтения в блочном режиме передачи Read Multiple

отличается от обычного (с обменом РІО) тем, что запросы прерывания вырабатываются не на каждый сектор, а на блок

секторов, размер которого задан командой Set Multiple Mode. Кроме того, в случае появления неисправимой ошибки чтения содержимое блока командных регистров не определено (не указывает на сбойный сектор). За счет сокращения чис-

ла прерываний, которые должен обслужить процессор, блочный режим в многозадачной системе позволяет повысить

производительность на 30%. Производительность обмена зависит от размера блока. Размер, оптимальный для устройства, может не быть оптимальным для ОС. Команда «длинного» чтения Read Long считывает сектор

данных вместе с контрольными байтами. При ее вызове регистр SC должен указывать на запрос только одного секто-

ра. Блок данных считывается 16-битными словами, а контрольные байты — 8-битными. Некоторые устройства АТА-1 неспособны быстро передавать байты ЕСС вслед за данными. Для их считывания используют 8-битный обмен в режиме PIO Mode 0. Команда верификации Read Verify Sector(s) в отличие от

обычного чтения не передает данные от устройства. В слу-

чае ошибки на адрес сбойного сектора указывает блок командных регистров. Запрос прерывания выполняется после исполнения команды. Команды записи Write DMA, Write Sector(s), Write Long, Write Multiple работают аналогично соответствующим им командам чтения и также имеют версии с повторами и без. Ко-

манда записи с верификацией Write Verify аналогична команде Write Sector(s), но для каждого сектора после записи выполняется контрольное считывание. Для логической инициализации (очистки области) дисков имеется команда записи Write Same, которая позволяет содержимое 512 байт, принятых от хоста, записать в группу секторов. Если в регистр свойств занесен код 22h, область записываемых секторов определяется регистрами командного блока. Если в регистр свойств занесен код DDh, запись производится во все доступные сек-

торы устройства. Команды чтения и записи буфера Read Buffer и Write Buffer служат для обмена в режиме РІО с 512-байтной буферной

памятью устройства (но не сектором носителя). Команда форматирования трека Format Track по входным пара-

метрам специфична для каждого устройства, и ее использование не рекомендуется. Многие устройства ее отвергают как недопустимую. Поскольку команда форматирования традиционно ориентирована на один трек, форматирование дисков

АТА в режиме трансляции геометрии, при котором физическая

манде поиска Seek устройство устанавливает головки на заданный цилиндр/трек и считывает идентификатор сектора. Команда рекалибровки Recalibrate заставляет устройство найти нулевой цилиндр. Если устройству это не удается, устанавливается бит ошибки Track O Not Found. Эту команду обычно применяют при обработке ошибок: часто после такого «встряхивания» ошибка не повторяется. После ус-

организация не совпадает с логической, невозможно. В накопителях с зонным форматом записи форматирование логического трека будет «накрывать» переменное число физических. Вспомогательное назначение имеют команды поиска. По ко-

пешного выполнения команды блок командных регистров содержит адрес первого сектора диска в формате, зависящем от режима адресации (LBA или CHS). Для накопителей со сменными носителями в АТА-2 были предназначены команды загрузки и выгрузки, подтверждения смены носителя, блокировки и разблокировки устройства —

Boot - Post-Boot, Boot - Pre-Boot, Media Eject, Acknowledge

Media Change, Door Lock, Door Unlock. Их реализация специфична для каждой модели устройства. В АТА-4 набор этих команд сокращен. Смену носителя вызывает только команда Media Eject (для устройств АТАРІ — пакетная команда Start/Stop Unit). Здесь может работать один из двух механизмов защиты от несанкционированной смены носителя. При использовании уведомления о смене носителя Removable

Media Status Notification нажатие кнопки на накопителе смены носителя не вызывает, этот факт и состояние носителя могут определяться по команде Get Media Status. Этот механизм включается и отключается соответствующими подкомандами Set Features; по любому сбросу устройства он отключается. Когда механизм уведомления отключен, работает другой: для запрета/разрешения смены носителей от кнопки устройства (только для непакетных устройств) применяют команды Media Lock/Media Unlock, они же используются

для определения состояния (наличия, защиты записи и факта смены носителя).

Для запоминающих устройств на флэш-памяти в ATA-4 ввели команды, начинающиеся с аббревиатуры CFA (Compact

Операция стирания занимает еще больше времени. Интерес представляет информация о состоянии сектора: стертый или нет и сколько раз выполнялась запись.

6.3.2. Служебные команды
В системе команд имеются средства идентификации и управления свойствами устройств. Команда идентификации Identify Device позволяет считать из контроллера блок из 256 слов, характеризующих устройство АТА. Устройства с пакетным интерфейсом эту команду должны отвергать, для них имеется команда Identify Packet Device (см. 6.7). Блок параметров может храниться как в энергонезависимой памяти устройства, так и на самом носителе в месте, недоступном для обычных обращений. Состав полей блока для непакетных устройств приведен в табл. 6.5. Графа «F/V» определяет свойства соответствующих полей: F — содержимое фиксиро-

вано, V — содержимое меняется в зависимости от состояния устройства или выполненных команд, X — специфично для данного устройства (может быть и F, и V), R — зарезервированные поля. Для устройств со сменными носителями зна-

Flash Association — ассоциация производителей компактных флэш-карт). Специфика этих устройств заключается в записи: запись обеспечивается лишь в предварительно стертые ячейки (сектор), хотя есть устройства, автоматически осуществляющие стирание при записи. Операция записи выполняется существенно медленнее, чем чтения, скорость которого приближается к скорости динамической памяти.

-

чения полей F могут меняться при смене носителя.

| Слово | F/V | Назначение                                      |
|-------|-----|-------------------------------------------------|
| 0     | F   | Общая конфигурационная информация               |
|       |     | Бит 15: 0 для всех устройств АТА                |
|       |     | Бит 7: 1 — устройство со сменным носителем      |
|       |     | Бит 6: 1 — устройство (контроллер) с несменным  |
|       |     | носителем                                       |
|       |     | Бит 0 — зарезервирован                          |
|       | 1   | Значение остальных бит специфично для устройств |
| 1     | F   | Число логических цилиндров                      |

| Слово | F/V | Назначение                                                                                                                           |
|-------|-----|--------------------------------------------------------------------------------------------------------------------------------------|
| 2     | R   | Зарезервировано                                                                                                                      |
| 3     | F   | Число логических головок                                                                                                             |
| 4     | X   | Специфично                                                                                                                           |
| 5     | X   | Специфично                                                                                                                           |
| 6     | F   | Число логических секторов на логическом треке                                                                                        |
| 7–9   | X   | Специфично                                                                                                                           |
| 10-19 | F   | Серийный номер (20 символов ASCII), если слово 10 ненулевое, иначе— специфичная информация                                           |
| 20    | X   | Специфично                                                                                                                           |
| 21    | X   | Специфично                                                                                                                           |
| 22    | F   | Число дополнительных байт в командах «длинного» чтения и записи (в АТА-4 объявлено устаревшим)                                       |
| 23-26 | F   | Версия встроенного ПО (8 символов ASCII), если слово 23 ненулевое, иначе — специфичная информация                                    |
| 27-46 | F   | Номер модели (40 символов ASCII), если слово 27 ненулевое, иначе — специфичная информация                                            |
| 47    | X   | Биты 15-8 специфичны (в АТА-4 – 80h)                                                                                                 |
|       | F   | Биты 7-0 — возможности множественных операций: 0 — зарезервирован, 01h-FFh — максимальное количество секторов, передаваемых за сеанс |
| 48    | R   | Зарезервировано                                                                                                                      |
| 49    |     | Возможности:                                                                                                                         |
|       | R   | Биты 15–14 — зарезервированы для Identify Packet Device                                                                              |
|       | F   | Бит 13— значения таймера режима Standby:<br>1— соответствуют стандарту,<br>0— задаются особо                                         |
| ĺ     | R   | Бит 12 зарезервирован для Identify Packet Device                                                                                     |
|       | F   | Бит 11:<br>1 — IORDY поддерживается (для PIO Mode 3 и<br>выше — обязательно),<br>0 — IORDY может поддерживаться                      |
|       | F   | Бит 10: 1 — сигнал IORDY может быть запрещен командой Set Features                                                                   |
|       | F   | Бит 9 =1 (в ATA-4 используется для Identify Packet Device, в ATA-2 — как указание на поддержку LBA и действительности слов 60-61)    |

| Таблица 6.5 ( <i>продолжение</i> ) |     |                                                                                                                                                                                                     |  |  |  |
|------------------------------------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Слово                              | F/V | Назначение                                                                                                                                                                                          |  |  |  |
|                                    | F   | Бит 8=1 (в ATA-4 используется для Identify Packet Device, в ATA-2 — как указание на поддержку DMA)                                                                                                  |  |  |  |
|                                    | X   | Биты 7-0 специфичны                                                                                                                                                                                 |  |  |  |
| 50                                 | F   | Возможности (ATA-4): Бит 15=0 Бит 14=1 Биты 13-1 — зарезервирован Бит 0=1 указывает на специфичное значение минимума для Standby Timer                                                              |  |  |  |
| 51                                 | F   | Биты 15-8: длительность цикла обмена в режиме PIO.<br>Если значение параметра не соответствует<br>режимам 0, 1 или 2, используется PIO Mode 0<br>Биты 7-0 специфичны                                |  |  |  |
| 52                                 | F   | Специфично. В АТА-2 биты 15–8: временной режим цикла одиночного обмена DMA (Single Word DMA). Если значение параметра не соответствует режимам 0, 1 или 2. используется Mode 0. Если полдерживаются |  |  |  |

слова 62 или 63, значение поля игнорируется X Биты 7-0 специфичны R Биты 15-3 зарезервированы F Бит 2: 1 — поля в слове 88 лействительны. 0 — нег

53 F 1 — поля в словах 64-70 действительны, Любое устройство, поддерживающее PIO Mode 3 и старше или Multiword DMA Mode 1 и выше,

лолжно использовать эти поля Бит 0: 1 — поля в словах 54-58 действительны, 0 — поля могут быть действительны

54 Текищее число логических цилиндров. Для устройств ATA-1, если команда Initialize Device Parameters не применялась, значение слова специфично

55 v Текущее число логических головок. Для устройств ATA-1, если команда Initialize Device Parameters не применялась, значение слова специфично

| Слово | F/V | Назначение                                                                                                                                                                                                            |  |
|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 56    | V   | Texyщee число логических секторов на трек. Для<br>устройств ATA-1, если команда Initialize Device<br>Parameters не применялась, значение слова<br>специфично                                                          |  |
| 57–58 | V   | Текущая емкость в секторах (произведение слов 54, 55, 56)                                                                                                                                                             |  |
| 59    | R   | Биты 15-9 зарезервированы                                                                                                                                                                                             |  |
| :     | V   | Бит 8: 1— установка для многосекторной передачи действительна                                                                                                                                                         |  |
|       | V   | Биты 7-0: текущая установка максимального числа секторов для многосекторных команд                                                                                                                                    |  |
| 60-61 | F   | Общее число секторов, адресуемых пользователем (только в режиме LBA)                                                                                                                                                  |  |
| 62    | V   | Для АТА-4 специфично, в АТА-2 — режим одиночного обмена DMA: Биты 15-8: активный режим: бит 8=1 — Mode 0, бит 9=1 — Mode 1 и т. д. Единичное значение может иметь только один бит                                     |  |
|       | F   | Биты 7-0 — поддерживаемые режимы:<br>бит 0=1 — Mode 0,<br>бит 1=1 — Mode 1 и т. д.                                                                                                                                    |  |
| 63    | v   | Режим множественного обмена Multiword DMA:<br>Биты 15-8: активный режим, аналогично слову 62                                                                                                                          |  |
|       | F   | Биты 7-0: поддерживаемые режимы, аналогично слову 62                                                                                                                                                                  |  |
| 64    | R   | Биты 15-8 зарезервированы                                                                                                                                                                                             |  |
|       | F   | Биты 7-0 — поддерживаемые прогрессивные режимы программного обмена (Advanced PIO): бит 0=1 — PIO Mode 3, бит 1=1 — PIO Mode 4, биты 2-7 — зарезервированы                                                             |  |
| 65    | F   | Минимальная длительность цикла передачи множественного DMA (в наносекундах)                                                                                                                                           |  |
| 66    | F   | Рекомендованная длительность цикла передачи множественного DMA (в напосекупдах). При многосекторной передаче обеспечивает оптимальную скорость, при которой устройство не будет тормозить поток снятием запроса DMARQ |  |

| DBO   | F/V     | Назначение |
|-------|---------|------------|
| блица | 6.5 (np | одолжение) |

| CHOBO | 17,4 | Пазпачение                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|-------|------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 67    | F    | Минимальная длительность цикла передачи PIO без<br>использования сигнала готовности<br>(в наносекундах)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                            |
| 68    | F    | Минимальная длительность цикла передачи PIO с<br>использованием сигнала готовности<br>(в наносекундах)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |
| 69-70 | R    | Зарезервировано для поддержки перекрытия команд и очередей                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
| 71-74 | R    | Зарезервировано для команды Identify Packet Device                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |
| 75    | F    | Глубина очереди команд:<br>Биты 15–5— зарезервированы<br>Биты 4–0— максимальная глубина очереди                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 76-79 | R    | Зарезервировано                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |
| 80    | F    | Номер основной версии интерфейса (если не 0000h или<br>FFFFh):<br>1 — ATA-1,<br>2 — ATA-2,<br>4 — ATA/ATAPI-4                                                                                                                                                                                                                                                                                                                                                                                                                                                                                      |
| 81    | F    | <i>Младший номер версии</i> интерфейса (если не 0000h или FFFFh)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |
| 82    | F    | Поддержка команд и свойств (если слова 82 и 83 не равны 0000h или FFFFh): Бит 15 — не используется Бит 14 — команды Nop Бит 13 — команды Read Buffer Бит 12 — команды Write Buffer Бит 11 — не используется Бит 10 — ограничение доступного пространства Бит 9 — команда Device Reset Бит 8 — вырабатывание прерывания во время выполнения команды Service Бит 7 — прерывание по освобождению шины Бит 6 — кэширование с упреждающим чтением Бит 5 — кэширование записи Бит 4 — команда Packet Бит 3 — управление энергопотреблением Бит 2 — смена носителя Бит 1 — команды Security Бит 0 — SMART |

| Слово  | F/V    | Назначение                                                                                                                                                                                                                                                                       |  |
|--------|--------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 83     | F      | Поддержка команд и свойств (как и слово 82): Бит 15 = 0 Бит 14 = 1 Биты 13-5 зарезервированы Бит 4 — уведомление о смене носителя Бит 3 — расширенное управление энергопотреблением Бит 2 — команды CFA Бит 1 — команды Read/Write DMA Queued Бит 0 — команда Download Microcode |  |
| 84     | F      | Поддержка команд и свойств (если слова 82, 83 и 84 не равны 0000h или FFFFh): Бит 15 = 0 Бит 14 = 1 Биты 13-0 зарезервированы                                                                                                                                                    |  |
| 85–87  | F      | Разрешенные команды и свойства; поля и правила аналогичны словам 82–84                                                                                                                                                                                                           |  |
| 88     | R      | Режим Ultra DMA Биты 15–11 зарезервированы Биты 10–8: активный режим Ultra DMA: бит 8–1 — Mode 0, бит 9–1 — Mode 1 и т. д. Единичное значение может иметь только один бит                                                                                                        |  |
|        | R<br>V | Биты 7–3 зарезервированы<br>Биты 2–0: поддерживаемые режимы одиночного<br>обмена DMA: бит 0=1 — Mode 0, бит 1=1 — Mode 1<br>и т. д.                                                                                                                                              |  |
| 89     | F      | Время защитного стирания: $0$ — не указано; значение $1-254$ , умноженное на $2$ , дает время в минутах, $255-6$ олее $508$ мин                                                                                                                                                  |  |
| 90     | F      | Время расширенного защитного стирания (аналогично слову 89)                                                                                                                                                                                                                      |  |
| 91     | V      | Текущий уровень<br>Advanced Power Management                                                                                                                                                                                                                                     |  |
| 92-126 | R      | Зарезервировано                                                                                                                                                                                                                                                                  |  |
| 127    | R<br>F | Биты 15-2 — зарезервированы Биты 1-0 — уведомление о смене носителя: 00 — не поддерживается, 01 — поддерживается, 1x — зарезервированы                                                                                                                                           |  |

#### полжение)

| Слово   | F/V | Назначение                                                                                                                                                                                                                                                                                                                                                |
|---------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 128     | V   | Состояние защиты: Биты 15-9 зарезервированы Бит 8 — уровень защиты: 0 — высокий, 1 — максимальный Биты 7-6 — зарезервированы Бит 5: 1 — поддержка расширенного защитного стирания Бит 4: 1 — счетчик попыток иссяк Бит 3: 1 — команды защиты блокированы Бит 2: 1 — устройство заблокировано Бит 1: 1 — защита разрешена Бит 0: 1 — защита поддерживается |
| 129-159 | X   | Специфично                                                                                                                                                                                                                                                                                                                                                |
| 160-255 | R   | Зарезервировано                                                                                                                                                                                                                                                                                                                                           |

ошибку «команда отвергнута» (прежняя спецификация АТА не четко описывала эту ситуацию, и некоторые системы не обнаруживали отказ при данной команде). После запроса неподдерживаемого режима трансляции устройство блокирует доступ к носителю с ошибкой ID Not Found до запроса

поддерживаемого режима трансляции. Устройство обязано поддерживать режим, описанный словами 1, 3 и 6 блока его

ное на единицу число логических головок. Если запрошенный режим трансляции устройство не поддерживает, оно выдаст

параметров. Некоторые устройства АТА-1 требовали, чтобы данная команда выполнялась до доступа к носителю. Команда установки свойств Set Features (специфичная для устройства) подразумевает помещение кода подкоманды (табл. 6.6) в регистр свойств.

#### Taffmura & & Conversion Consequence Constitution Constitution

|      | o.o. i indivomentite settemm enoners fer powerse |
|------|--------------------------------------------------|
| Код  | Назначение                                       |
| 01h1 | Разрешение 8-битного обмена                      |
| 02h  | Разрешение кэширования записи                    |

| Код              | Назначение                                                                            |
|------------------|---------------------------------------------------------------------------------------|
| 03h              | Установка режима передачи по значению регистра SC (табл. 6.7)                         |
| 04h1             | Разрешение автоматического переназначения дефектных<br>блоков                         |
| 05h              | Разрешение расширенного управления энергопотреблением (уровень в регистре <i>SC</i> ) |
| 31h              | Запрет уведомления о смене носителя                                                   |
| 33h1             | Запрет повторов                                                                       |
| 44h <sup>1</sup> | Установка количества дополнительных байт в командах<br>Read Long/Write Long           |
| 54h¹             | Установка количества сегментов кэша по значению регистра<br>SC                        |
| 55h              | Запрет упреждающего чтения                                                            |
| 5Dh              | Разрешение прерывания по освобождению шины                                            |
| 5Eh              | Разрешение прерывания при выполнении команды Service                                  |
| 66h              | Запрет возврата к параметрам по умолчанию при включении питания                       |
| 77h¹             | Запрет ЕСС                                                                            |
| 81h <sup>1</sup> | Запрет 8-битного обмена                                                               |
| 82h              | Запрет кэширования записи                                                             |
| 84h1             | Запрет автоматического переназначения дефектных блоков                                |
| 85h              | Запрет расширенного управления энергопотреблением                                     |
| 88h1             | Разрешение ЕСС                                                                        |
| 99h¹             | Разрешение повторов                                                                   |
| 9Ah¹             | Ограничение тока потребления значением в регистре SC,<br>умноженным на 4 (мА)         |
| AAh              | Разрешение упреждающего чтения                                                        |
| ABh <sup>1</sup> | Установка максимального количества кэшируемых блоков по регистру <i>SC</i>            |
| BBh1             | Установка 4-байтной длины дополнительного поля<br>для команд Read Long/Write Long     |
| CCh              | Разрешение возврата к параметрам по умолчанию при включении питания                   |
| DDh              | Запрет прерывания по освобождению шины                                                |
| DEh              | Запрет прерывания при выполнении команды Service                                      |
| ¹ B ATA-         | 4 подкоманда изъята.                                                                  |

ленные свойства заменяются на принятые по умолчанию. Результат подкоманд можно и закрепить, подав подкоманду 66h (отмена — подкоманда с кодом CCh). Таблица 6.7. Управление режимом обмена

После включения питания или аппаратного сброса установ-

Биты [7:0] Режим обмена

| <u> </u>  |                                                               |
|-----------|---------------------------------------------------------------|
| 0000 000  | Режим PIO, принятый для устройства по умолчанию               |
| 00000 001 | Режим РІО, принятый для устройства по умолчанию; запрет IORDY |
| 00001 nnn | Режим PIO Mode x* с сигналом IORDY                            |
| 00010 nnn | Режим одиночного DMA Mode x                                   |
| 00100 nnn | Режим множественного DMA Mode x                               |
| 01000 nnn | Режим Ultra DMA Mode x                                        |
| 10000 nnn | Зарезервированы                                               |

Команда задания параметров блочного режима передачи Set Multiple Mode через регистр SC указывает число секторов,

передаваемых с одним запросом прерывания. Значению SC=0 соответствует запрет блочного режима. После включения питания или аппаратного сброса блочный режим запрещен. Команда диагностики Execute Device Diagnostic, адресуясь все-

гда к ведущему устройству, выполняется одновременно обоими устройствами. О ее результате ведомое устройство сообщает ведущему (сигналом PDIAG#). Состояние обоих устройств определяется по диагностическому коду (табл. 6.8), который счи-

тывается из бит [6:0] регистра ошибок нулевого устройства. Фиктивная команда Nop, не изменяя содержимого регистров,

позволяет считать информацию о состоянии устройства, выполнив всего одну 16-битную запись по адресу в регистре DH. Команда всегда возвращает бит ошибки «команда отвергну-

та». В АТА-4 команда объявлена обязательной для устройств АТАРІ и всех, поддерживающих перекрывающиеся команды.

Она имеет подкоманды, указываемые в регистре свойств. Подкоманда с кодом 00 сбрасывает всю оставшуюся очередь, а с кодом 01 (NOP Auto Poll) на очередь не влияет.

Таблица 6.8. Диагностические коды

| КОД          | ведущее устроиство | ј ведомое устроиство      |
|--------------|--------------------|---------------------------|
| 01h          | Нормально          | Нормально или отсутствует |
| 00h, 02h-7Fh | Неисправно         | Нормально или отсутствует |
| 81h          | Нормально          | Неисправно                |
| 80h, 82h-FFh | Неисправно         | Неисправно                |

# Устройства АТА и АТАРІ могут поддерживать управление

энергопотреблением, защищать данные от несанкционированного доступа, выполнять мониторинг своего состояния для предупреждения об угрозе отказа и перезаписывать встроенную микропрограмму.

встроенную микропрограмму.

Средства управления энергопотреблением — Power Management — не обязательны. Различают следующие состояния, перечисленные в порядке возрастания энергопотребления:

Sleep — «заснувшее» устройство — потребляет минимум энергии, «разбудить» его может только сброс. Время «пробуж-

дения» — не более 30 с. Standby Mode (дежурный режим) — устройство способно принимать команду по интерфейсу, но для доступа к носителю может потребоваться столь же большое время. В это состояние устройство может перейти как по команде, так и по таймеру (Standby Timer), отсчитывающему время от последнего

запроса, полученного в состоянии ожидания или активном состоянии. Время срабатывания таймера программируется;

он может быть запрещен.

Idle Mode (состояние ожидания) — устройство способно сразу начать обслуживание обращения к носителю, не слишком быстро, так как некоторые узлы отключены.

Active Mode (активный режим) — устройство все запросы обслуживает за кратчайшее время.

Команда проверки режима энергопотребления *Check Power Mode* через регистр *SC* возвращает состояние: *SC*=0 — устройство находится в состоянии *Standby* или переходит в него, *SC*=255 — устройство активно или в состоянии ожидания.

SC программирует таймер дежурного режима (табл. 6.9). Команда *Idle Immediate* непосредственного перевода в режим ожидания таймер не программирует.

Команда *Idle* переводит устройство в режим ожидания из активного или дежурного режимов, а также через регистр

# Таблица 6.9. Тайы-аут перехода в дежурный режим

| Содержимое SC       | Тайм-аут                                            |
|---------------------|-----------------------------------------------------|
| 0 (00h)             | Тайм-аут запрещен                                   |
| x=1-240 (01h-F0h)   | (x×5) c                                             |
| x=241-251 (F1h-FBh) | ((x-240)×30) мин                                    |
| 252 (FCh)           | 21 мин                                              |
| 253 (FDh)           | Период, заданный производителем (в пределах 8-12 ч) |
| 254 (FEh)           | Зарезервировано                                     |
| 255 (FFh)           | 21 мин 15 с                                         |

Команда Sleep является единственным способом перевода устройства в «спящий» режим. После получения команды устройство генерирует запрос прерывания. Хост должен считать регистр состояния, что сбросит прерывание и позволит устройству «заснуть». «Разбудить» устройство можно только аппаратным или программным сбросом. Состояние, в которое оно перейдет, определяется типом сброса и программируется. Поскольку не каждый хост «знает», что после команды нужно прочитать регистр состояния, устройство автоматически сбросит запрос прерывания и «заснет» через

определенный период времени (не менее 2 с). Команда *Standby* переводит устройство в дежурный режим потребления и через параметр в регистре *SC* программирует таймер. Команда *Standby Immediate* таймер не программирует.

Устройства могут поддерживать расширенное управление энергопотреблением *APM (Advanced Power Management)*. При этом задается уровень *APM Level*, определяющий степень активности: 01h — минимальное потребление, FEh — макси-

мальная производительность. Уровень выше 80h не позво-

пользовать также команды пакетного протокола. Начиная с ATA-3 в стандарт введена *группа команд защиты*. Защищенное устройство по включению питания или аппаратному сбросу будет находиться в заблокированном состоянии, при котором любой доступ к информации на носите-

ляет устройству останавливать двигатель. APM управляется подкомандами Set Features. Устройства с пакетным интерфейсом для управления энергопотреблением могут истройства с пакетным истрофейсом для управления энергопотреблением могут истрофейсом.

ле запрещен. Система защиты поддерживает два пароля — главный (Master Password) и пользовательский (User Password). Главный пароль устанавливается изготовителем или продавцом устройства. Пароль устанавливается командой Security

Set Password, этой же командой устанавливается защита. В

передаваемом блоке данных (512 байт) нулевое слово является управляющим:

Вит 0 определяет тип пароля (0 — User, 1 — Master);

Бит 8 определяет степень защиты (0 — High, 1 — Maximum).

Слова 1–16 содержат пароль, остальные игнорируются. При установке главного пароля состояние защиты не меняется. Разблокировать, устройство, позволяет, команда. Security

Разблокировать устройство позволяет команда *Security Unlock*, при этом необходимо указать пароль пользователя. Если пароль утерян, можно использовать главный пароль,

но доступ к данным будет предоставлен, только если была выбрана степень защиты High. Если была выбрана степень защиты Махітит, разблокировать устройство по главному паролю можно только командой Security Erase Unit, но при этом вся информация с носителя будет стерта. Чтобы за-

страховаться от случайного стирания, непосредственно перед этой командой должна быть выполнена команда Security Erase Prepare. Команда Security Freeze Lock блокирует выполнение любых команд защиты до следующего сброса. Для осложнения подбора пароля (его длина составляет 32 байт)

осложнения подоора пароля (его длина составляет 32 оаит) служит счетчик неудачных попыток разблокировки, по срабатывании которого команды разблокировки будут отвергаться до выключения питания или аппаратного сброса. От-

гаться до выключения питания или аппаратного сброса. Отменить защиту разблокированного устройства можно командой Security Disable Password (предъявив один из двух

паролей).

Address. Узнать реальный максимальный адрес позволяет команда Read Native Address.

Для предупреждения о возможном отказе устройства служит технология SMART (Self-Monitoring, Analysis and Reporting Technology — технология самонаблюдения, анализа и сообщений). Предсказуемые отказы (Predictable Failure) появляются в результате выхода параметров за некоторый порог. Отслеживаемые параметры: время разгона до заданной

скорости, время позиционирования, процент ошибок позиционирования, высота полета головок, производительность (зависящая от числа повторов), количество использованных резервных секторов и др. Мониторинг может осуществляться двояко: в рабочем режиме (On-Line) одновременно с выполнением команд хоста (при некотором возможном замедлении). Мониторинг Off-Line выполняется устройством в паузе между «полезными» командами, не снижая производительности. Если во время выполнения этой процедуры придет внешняя команда, то мониторинг прервется на время исполнения команды, но начало исполнения команды может задержаться на время до двух секунд. Значения ат-

Команды защиты в ATA-4 дополнены ограничением максимального адреса, доступного пользователю (сообщаемого в блоке параметров идентификации), командой Set Max

рибутов, за которыми ведется наблюдение, сохраняются в энергонезависимой памяти устройства.

Для непакетных устройств имеется команда Smart (пакетные используют для этих целей собственный протокол), подкоманды которой задаются через регистр свойств. Из этих подкоманд стандартизованы следующие:

Smart Read Data (D0h) — чтение блока данных SMART;

Smart Enable/Disable Attribute Autosave (D2h) — управление автосохранением атрибутов;

Smart Execute Off-Line Immediate (D4h) — немедленное выполнение мониторинга Off-Line;

Smart Enable Operations (D8h) — разрешение команд и внутренних функций SMART;

Smart Save Attribute Values (D3h) — сохранение значений

атрибутов;

ций SMART;

Smart Return Status (DAh) — опрос результатов мониторинга. Если какой-либо порог перейден, регистры СН и СL будут иметь значения C2h и 4Fh соответственно, если

Smart Disable Operations (D9h) — запрет команд и функ-

все в порядке — 2Ch и F4h.

Команда загрузки микрокода Download Microcode позволяет модифицировать firmware — встроенное ПО устройства. В зависимости от кода в регистре свойств загруженный микрокод будет действовать до выключения питания (FR=01h) или постоянно (FR=07h). Количество загруженных блоков задается регистром SN (старший байт) и SC (младший байт). Таким образом может быть загружено от 0 до 33 553 920 байт, что более чем достаточно для встроенного ПО. Некорректная модификация кода может привести к выходу устрой-

# 6.4. Протоколы взаимодействия хоста и устройства Обычный протокол взаимодействия хоста с устройством

ства из строя.

обычный протокол взаимодействия хоста с устроиством выглядит следующим образом:

1. Хост читает регистр состояния устройства, дожидаясь

нулевого значения бита BSY. Если присутствуют два уст-

- ройства, хост обращается к ним «наугад» состояние будет сообщать последнее выбранное устройство.

  2. Дождавшись освобождения устройства, хост записывает в регистр *DH* байт, у которого бит *DEV* указывает на адресуемое устройство. Здесь кроется причина невозмож
  - в регистр *он* оаит, у которого оит *ое* указывает на адресуемое устройство. Здесь кроется причина невозможности параллельной работы двух устройств на одной шине ATA: обратиться к устройству можно только после освобождения обоих устройств.

    3. Хост читает основной или альтернативный регистр со-
- Хост читает основной или альтернативный регистр состояния адресованного устройства, дожидаясь признака готовности (DRDY=1).
- готовности (*DRDY*=1).

  4. Хост заносит требуемые параметры в блок командных регистров.

6. Устройство устанавливает бит BSY и переходит к исполнению команды. Дальнейшие действия зависят от прото-

кола передачи данных, заданного командой (см. графу

5. Хост записывает код команды в регистр команд.

Для команд, не требующих передачи данных (ND):

«Протокол» в табл. 6.4).

ошибок уже имеется информация о результате исполнения. Выполнение завершается.

Единичное значение бита BSY может промелькнуть между шагами 6 и 7 так быстро, что хост его не зафиксирует, но для фиксации факта выполнения команды или ее части и

7. Завершив исполнение команды, устройство сбрасывает бит *BSY* и устанавливает запрос прерывания (если он не запрещен). К этому моменту в регистрах состояния и

- предназначен запрос прерывания.

  Для команд, требующих *чтения данных в режиме PIO (PI)*:
- Подготовившись к передаче первого блока данных по шине ATA, устройство устанавливает бит DRQ. Если была ошибка, она фиксируется в регистрах состояния и ошибок. Далее устройство сбрасывает бит BSY и устанавли-

вает запрос прерывания (если он не запрещен).

- 8. Зафиксировав обнуление бита BSY (или по прерыванию), хост считывает регистр состояния, что приводит к сбросу прерывания от устройства.
  9. Если хост обнаружил единичное значение бита DRQ, он
- производит чтение первого блока данных в режиме PIO (адресуясь к регистру данных). Если обнаружена ошибка, считанные данные могут быть недостоверными.
- после передачи блока данных возможно одно из следующих действий:
- Если на шаге 8 ошибка не обнаружена, а требуется передача следующего блока, устройство устанавливает бит ВЅУ, и данная последовательность повторяется с шага 7.

Для *операций записи данных* после шага 6 для устройства начинается активная фаза записи на носитель, что отмечается установкой бита *BSY*.

Для команд, требующих *записи данных в режиме PIO (PO и P)*:

7. Подготовившись к приему первого блока данных по шине

завершается.

Если есть ошибка или передан последний блок данных, устройство сбрасывает бит *DRQ* и выполнение команды

бок) и сбрасывает бит *BSY*. Если была ошибка, она фиксируется.

8. Зафиксировав обнуление бита *BSY*, хост считывает регистр состояния.

ATA, устройство устанавливает бит DRQ (если нет оши-

производит запись первого блока данных в режиме РІО по адресу в регистре данных.

10. После передачи блока данных возможно одно из следующих действий:

Если обнаружена ошибка, устройство сбрасывает бит *DRQ*, устанавливает запрос прерывания и выполнение коман-

Если хост обнаружил единичное значение бита *DRQ*, он

- ды завершается. Переданные по шине данные остаются необработанными устройством (не записываются на носитель).
- Если ошибка не обнаружена, устройство устанавливает бит BSY и переходит к следующему шагу.
- 11. Устройство обрабатывает принятый блок данных, затем:
- если нет ошибок и обработанный блок последний, устройство сбрасывает бит BSY и устанавливает запрос прерывания, на чем выполнение команды успешно завершастел.
- ется;
  « если обнаружена ошибка, выполнение команды заверша-
- ется таким же образом, но с установкой бит ошибок; если нет ошибок и требуется передача следующего блока, выполняются следующие шаги:

- По готовности приема следующего блока устройство устанавливает бит *DRQ*, сбрасывает бит *BSY* и устанавливает запрос прерывания.
- 13. По обнулению бита *BSY* (или по прерыванию) хост считывает регистр состояния.14. Обнаружив бит *DRQ*, хост выполняет запись очередного
- блока в регистр данных, и последовательность повторяется с шага 11.

  Команды с передачей данных в режиме DMA выполняются

похожим образом, но:

Вместо РІО используется прямой доступ к памяти. Хост

должен проинициализировать канал DMA до записи кода в регистр команд, чтобы по появлении сигнала DMARQ начался обмен.

Запрос прерывания даже в многосекторных передачах

# 6.5. Протоколы и режимы передачи данных

производится один раз — по выполнении команды.

# Программа общается с устройствами АТА через регистры, используя инструкции ввода/вывода *IN* и *OUT*. Для переда-

чи данных с максимальной скоростью применяют программный доступ к регистру данных или DMA. Тип обмена задается командой. Программный доступ обязателен для всех устройств. Команды режима DMA устройствами могут не поддерживаться.

поддерживаться.

Программный доступ PIO (Programmed Input/Output) выполняется в виде следующих друг за другом операций чтения или записи в пространстве ввода/вывода по адресу регистра данных. В отличие от программно-управляемого ввода/вывода, применяемого, например, для общения с LPT-

портом, передача блока данных в режиме РІО производится без программного опроса какого-либо бита готовности для передачи каждого слова. Готовность устройства проверяется перед началом передачи блока, после чего хост производит

серию операций в определенном темпе. Темп определяется выбранным режимом *PIO Mode*. Для режимов определены

щью инструкций ввода/вывода строк REP INS или REP OUTS с занесенным в регистр СХ количеством слов (или байт) в передаваемом блоке. Эти инструкции обеспечивают максимально возможную скорость обмена для данного процессора и системной шины. «Обуздать» процессор в соответствии

с выбранным режимом входит в задачу адаптера АТА, кото-

допустимые параметры временной диаграммы цикла обмена (табл. 6.10). Обмен PIO программно реализуется с помо-

рый использует для удлинения цикла сигнал готовности шины (для ISA — IOCHRDY). Традиционные режимы 0, 1 и 2 имеют временные параметры, фиксируемые только хост-адаптером. Для прогрессивных режимов ATA-2 (PIO Mode 3 и старше) устройство может затормозить обмен, используя сигнал готовности IORDY. Программный обмен на все время передачи блока занимает и процессор, и системную шину.

| PIO<br>mode | Минимальное<br>время цикла, нс | Скорость<br>передачи,<br>Мбайт/с | Интерфейс                                 |
|-------------|--------------------------------|----------------------------------|-------------------------------------------|
| )           | 600                            | 3,3                              | ATA                                       |
|             | 383                            | 5,2                              | ATA                                       |
|             | 240                            | 8,3                              | ATA                                       |
| ,           | 180                            | 11,1                             | E-IDE, ATA-2<br>(используется IORDY)      |
| Į.          | 120                            | 16,6                             | E-IDE, Fast ATA-2<br>(используется IORDY) |

Обмен по каналу DMA занимает исключительно шины ввода/ вывода и памяти. Процессору требуется выполнить только

вывода и памяти. Процессору требуется выполнить только процедуру инициализации канала, после чего до прерывания от устройства в конце передачи блока он свободен (этим мо-

от устройства в конце передачи блока он свободен (этим могут воспользоваться многозадачные системы). Стандартные каналы DMA шины ISA для интерфейса ATA практически не используются из-за низкой пропускной способности. Вы-

не используются из-за низкой пропускной способности. Высокопроизводительные адаптеры ATA могут иметь собственные более эффективные контроллеры. Режимы обмена по ка-

налу DMA бывают одиночными и множественными. При одиночном режиме (Single Word DMA) устройство для переда-

сывает его по сигналу DMACK#, подтверждающему цикл обмена. При *множественном режиме* (*Multiword DMA*) на сигнал DMARQ хост отвечает потоком циклов, сопровождаемых сигналами DMACK#. Если устройство не справляется с потоком, оно может приостановить его снятием сигнала DMARQ, а

по готовности установить его снова. Множественный режим

позволяет развить более высокую скорость передачи.

чи каждого слова вырабатывает сигнал запроса DMARQ и сбра-

Новейшее достижение — режим *Ultra DMA*, позволяющий достигнуть скорости передачи 33 Мбайт/с и обеспечить достоверность передачи, чего не делалось ни в PIO, ни в стандартных режимах DMA (а зря!). Стандартом ATA-4 определено 3 режима Ultra DMA (0, 1 и 2), выбор режима осуществляется

командой Set Features. В режимах Ultra DMA сигналы DMARQ и DACK# сохраняют свое назначение, а вот смысл сигналов DIOR#, DIOW# и IORDY на время передачи пакета (Ultra DMA Burst) существенно меняется (см. 6.1). В пакете данные на шине сопровождаются стробом, генерируемым источником данных, причем для синхронизации используются оба перепада сигналов. Это позволяет повысить пропускную способ-

ность шины, не увеличивая частоту переключений сигналов сверх 8,33 с¹ (этот предел для обычного кабеля достигается в режиме PIO Mode 4 и Multiword DMA Mode 2). Каждое переданное слово участвует в подсчете CRC-кода, который передается в конце пакета. Подсчет ведется и источником данных, и приемником. При несовпадении принятого и ожидаемого кода фиксируется ошибка передачи. Передача в пакете может приостанавливаться, если приемник снимет сигнал готовности (DDMARDY# или HDMARDY#). Передача пакета может прекращаться по инициативе устройства (снятием сигнала) или хоста (сигналом STOP). Противоположная сторона должна подтвердить окончание цикла сигналом STOP или

Правильный выбор режима обмена обеспечивает надежность и производительность. Все устройства поддерживают режим РІО Mode 0, в котором считывается блок параметров идентификации. В блоке имеются поля, описывающие режим обмена по умолчанию и более эффективные режимы обмена, поддерживаемые устройством. Командой Set Features

DMARQ соответственно.

обеспечивает надежной передачи данных в заявленном высокоскоростном режиме. Если данные начинают пропадать, первым делом следует понизить режим обмена. Параметры стандартных режимов обмена по DMA приведе-

можно изменить параметры режима. Иногда накопитель не

Параметры стандартных режимов обмена по DMA приведены в табл. 6.11.

# ны в таол. 6.11. Таблица 6.11. Параметры циклов DMA для интерфейса ATA

Минимальное время Скорость передачи,

Режим

|                        | цикла, нс | Мбайт/с |
|------------------------|-----------|---------|
| Single word DMA Mode 0 | 960       | 2,08    |
| Single word DMA Mode 1 | 480       | 4,16    |
| Single word DMA Mode 2 | 240       | 8,33    |
| Multiword DMA Mode 0   | 480       | 4,12    |
| Multiword DMA Mode 1   | 150       | 13,3    |
| Multiword DMA Mode 2   | 120       | 16,6    |
| Ultra DMA Mode 0       | 240*      | 16,6    |
| Ultra DMA Mode 1       | 160*      | 25      |
| Ultra DMA Mode 2       | 120*      | 33      |

слова данных, один по фронту синхронизирующего сигнала, другой — по спаду.

BIOS определяет режим обмена с каждым устройством с учетом ограничений, заданных в Setup. Старые диски, не сообщающие своих параметров, могут не работать со старшими режимами PIO. На одном шлейфе (канале ATA) могут присутствовать устройства с развым режимом обмена — специ-

режимами РІО. На одном шлейфе (канале ATA) могут присутствовать устройства с разным режимом обмена — спецификация это допускает. Однако реально могут возникать аппаратные или программные ограничения. Некоторые чипсеты не позволяют независимо программировать режим обмена или устройств канала. В таком случае при политичествания или устройств канала.

сеты не позволяют независимо программировать режим обмена для устройств канала. В таком случае при подключении двух разных устройств (например, PIO Mode 1 и 3) обмен с обоими устройствами будет происходить со скоростью меньшего (PIO Mode 1). Поэтому не рекомендуется к одному каналу ATA (порту IDE, что то же самое) подключать быстрый винчестер и медленный CD-ROM. Иногда за-

вязка режимов обмена двух устройств обусловлена ограни-

ченным набором параметров конфигурации в BIOS. Быстрые режимы множественного обмена по DMA реализуются только драйверами ОС. «Глупый» драйвер может попытаться навязать медленный режим обоим устройствам канала, так что смешивать разные устройства не стоит и по этой причине. Протокол обмена *PIO* хорош только для однозадачных ОС. Для многозадачных ОС больший интерес представляет обмен по DMA, если, конечно, поддерживаемый режим обеспечивает приемлемую скорость обмена (сравните табл. 6.10 и 6.11).

### 6.6. Средства многозадачности (АТА-4)

стемах является то, что когда одно устройство на шине исполняет команду, другое использоваться не может. В этом ATA существенно уступает SCSI, где устройства на время длительной внутренней операции могут освобождать шину и имеется эффективный механизм организации очередей процессов ввода/вывода. Спецификация ATA-4 определяет возможности параллельного выполнения команд обоими устройствами и создания очередей.

Главным недостатком интерфейса АТА в многозадачных си-

Перекрытие команд — Overlapped Feature — позволяет устройству, занятому длительной внутренней операцией, освободить шину. Для этого устройство должно сбросить биты DRQ и BSY регистра состояния. По окончании выполнения операции устройство устанавливает бит SERV в своем регистре состояния. Если хост намерен использовать шину для обращения к другому устройству, он должен запретить прерывания от устройства, установив бит nIEN в регистре управления. После того как хост вернется к обслуживанию устройства, он должен послать ему команду NOP с подкомандой 01 для получения информации о состоянии. При этом он может разрешить прерывание, которое произойдет по готовности устройства к продолжению. Обнаружив установленный бит SERV, хост посылает команду Service, которая вызовет продолжение исполнения команды, во время которой шина освобождалась. Принятый механизм продолжения менее эффективен, чем в SCSI, — он требует привлечения хоста для обнаружения готовности устройства. Передой 01), Packet, Read DMA Queued, Service и Write DMA Queued.
Устройства могут поддерживать очереди команд, но только для команд, допускающих перекрытие (эти свойства тесно

связаны). Если при наличии команд в очереди устройство получает команду, не входящую в этот список, команда отвергается (с соответствующим битом в регистре ошибок) и очередь сбрасывается. Глубина очереди, поддерживаемой устройством, сообщается в блоке параметров идентификации. Команды ставятся в очередь с уникальным идентификатором-тегом, который передается через регистр счетчика секторов. После исполнения команды Service значение тега для обслуживаемой команды считывается из того же регистра, что позволяет ее идентифицировать. Если устройство получает команду со значением тега, которое уже присутствует в очереди, и новая, и старая команды отвергаются (состояние не определено). При возникновении любой ошибки вся очередь сбрасывается. Следующая команда в очередь

крытие допускается только для команд NOP (с подкоман-

посылается лишь при освобожденной шине. Перед посылкой хост должен запретить прерывания, а разрешить их может только после посылки новой команды. Если для выполнения команды устройству не нужно освобождать шину, команда будет выполнена немедленно, а находящиеся в очереди команды, освободившие шину, будут выполнены позже. Очереди SCSI более эффективны как по набору команд (в очередь ставятся процессы, которые могут представлять собой цепочки команд), так и по гибкости управления. SCSI также обеспечивает независимость исполнения одних команд очереди от результатов выполнения других.

### 6.7. Пакетный интерфейс АТАРІ

Для подключения к интерфейсу ATA накопителей CD-ROM и стриммеров (а также других устройств) набора регистров и системы команд ATA недостаточно. Для них существует

аппаратно-программный интерфейс ATAPI (ATA Package Interface — пакетный интерфейс ATA). Устройство ATAPI поддерживает минимальный набор команд ATA, который

устройств со SCSI и ATAPI. Классификация устройств совпадает с принятой в SCSI (см. табл. 5.12), класс устройства сообщается им в начале блока параметров идентификации. Интерфейс АТАРІ может использоваться с неинтеллектуальными адаптерами АТА, поскольку для хост-адаптера поддержка АТАРІ может выполняться чисто программно. Сложные контроллеры АТА, имеющие кэш-память и собственный процессор, неориентированные на интерфейс ATAPI, могут не догадаться, что в регистр данных устройства кроме 512-байтных блоков данных можно записывать 16-байтный с командным пакетом. Устройства АТАРІ имеют следующие особенности: Команду Identify Device они должны отвергать, чтобы хост не пытался к ним обратиться как к АТА-устройствам. Для идентификации устройств АТАРІ предназначена специальная команда Identify Packet Device, а блок параметров, сообщаемых устройством, трактуется иначе (табл. 6.12). Для программного сброса устройства АТАРІ предназначена команда Device Reset, которую устройства ATA отвергают. Программный сброс через регистр управления не прекращает выполнения команды Packet. Специфические команды вместе с необходимыми параметрами передаются по команде Packet, код которой яв-

неограниченно расширяется 16-байтным командным *паке*том, посылаемым хост-контроллером в регистр данных устройства по команде *Packet*. Структура командного пакета пришла от SCSI, что обеспечивает схожесть драйверов для

|       |     | иствительным для устроиств АТА.<br>эфикация устройств АТАР!                                                                                                     |
|-------|-----|-----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Слово | F/V | Назначение                                                                                                                                                      |
| 0     | F   | Общая конфигурационная информация Биты [15:14] = 10 для всех устройств АТАРІ Бит 13 — зарезервирован Биты 12-8 — набор поддерживаемых команд (класс устройства) |

Бит 13 — зарезервирован
Биты 12-8 — набор поддерживаемых команд
(класс устройства)
Бит 7: 1 — устройство со сменным носителем
Бит 6-5:
00 — устройство установит *DRQ* в течение
3 мс после получения команды *Packet*,

| Слово | F/V | Назначение                                                                                                                                                                                                                                                                                        |  |
|-------|-----|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
|       |     | 01 — устройство введет INTRQ по установке DRQ после получения команды Packet, 10 — устройство установит DRQ в течение 50 мкс после получения команды Packet, 11 — зарезервировано Биты 4-2 — зарезервированы Биты 1-0 — длина командыюго пакета: 00 — 12 байт, 01 — 16 байт, 1х — зарезервировано |  |
| 1-9   | R   | Зарезервировано                                                                                                                                                                                                                                                                                   |  |
| 10-19 | F   | Серийный номер (20 символов ASCII), если слово 10 не нулевое; иначе— специфичная информация                                                                                                                                                                                                       |  |
| 20-22 | R   | Зарезервировано                                                                                                                                                                                                                                                                                   |  |
| 23-26 | F   | Версия встроенного ПО (8 символов ASCII), если слово 23 не нулевое; иначе — специфичная информация                                                                                                                                                                                                |  |
| 27–46 | F   | Номер модели (40 символов ASCII), если слово 27 не нулевое; иначе — специфичная информация                                                                                                                                                                                                        |  |
| 47-48 | R   | Зарезервировано                                                                                                                                                                                                                                                                                   |  |
| 49    |     | Возможности:                                                                                                                                                                                                                                                                                      |  |
|       | F   | Бит 15: 1— поддержка чередующегося<br>(interleaved) DMA                                                                                                                                                                                                                                           |  |
|       | F   | Бит 14: 1 — поддержка очередей команд                                                                                                                                                                                                                                                             |  |
|       | F   | Бит 13: 1— поддержка перекрывающихся<br>команд                                                                                                                                                                                                                                                    |  |
| :     | F   | Бит 12: 1— требуется программный сброс<br>(устарело)                                                                                                                                                                                                                                              |  |
|       | F   | Бит 11:<br>1— IORDY поддерживается (для PIO Mode 3<br>и выше— обязательно),<br>0— IORDY не обязано поддерживаться                                                                                                                                                                                 |  |
|       | F   | Бит 10: 1 — сигнал IORDY может быть запрещен командой Set Features                                                                                                                                                                                                                                |  |
|       | F   | Бит 9: 1— поддержка LBA                                                                                                                                                                                                                                                                           |  |
|       | F   | Бит 8: 1— поддержка DMA                                                                                                                                                                                                                                                                           |  |
|       | Х   | Биты 7-0 специфичны                                                                                                                                                                                                                                                                               |  |

Таблица 6.12 (продолжение) F/V Слово Назначение 50 R Зарезервировано F Биты 15-8: номер PIO Mode 51 Биты 7-0 специфичны X 52 R Зарезервировано 53 R Биты 15-3 зарезервированы

| 33    | F      | Биты 13-3 зарезервированы Бит 2: 1 — поля в слове 88 действительны, 0 — нет                                                                                                                |
|-------|--------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|       | F      | Бит 1:<br>1 — поля в словах 64-70 действительны,<br>0 — нет<br>Устройство, поддерживающее PIO Mode 3<br>и старше или Multiword DMA Mode 1 и выше,<br>должно использовать эти поля          |
|       | V      | Бит 0:<br>1— поля в словах 54–58 действительны,<br>0— поля могут быть действительны                                                                                                        |
| 54-62 | R      | Зарезервировано                                                                                                                                                                            |
| 63    | R      | Режим множественного обмена Multiword DMA: Биты 15–11 зарезервированы Биты 10–8: активный режим: бит 8=1 — Mode 0, бит 9=1 — Mode 1 и т. д. Единичное значение может иметь только один бит |
|       | R<br>V | Биты 7–3 зарезервированы<br>Биты 2–0: поддерживаемые режимы: бит 0=1 —<br>Mode 0, бит 1=1 — Mode 1 и т. д.                                                                                 |
| 64    | R      | Биты 15-8 зарезервированы                                                                                                                                                                  |
|       | F      | Биты 7-0— поддерживаемые прогрессивные<br>режимы программного обмена (Advanced PIO):                                                                                                       |

|    | F | Биты 7-0 — поддерживаемые прогрессивные режимы програминого обмена (Advanced PIO): бит 0=1 — PIO Mode 3, бит 1=1 — PIO Mode 4, биты 2-7 — зарезервированы                                                      |
|----|---|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 65 | F | Минимальная длительность цикла передачи множественного DMA (в наносекундах)                                                                                                                                    |
| 66 | F | Рекомендованная длительность цикла передачи множественного DMA (в наносекундах). При многосекторной передаче обеспечивает оптимальную скорость, при которой устройство не тормозит поток снятием запроса DMARQ |

| Слово | F/V                                              | Назначение                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
|-------|--------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| CIUBU | <del>                                     </del> |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 67    | F                                                | Минимальная длительность цикла передачи PIO без использования сигнала готовности (в наносекундах)                                                                                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 68    | F                                                | Минимальная длительность цикла передачи PIO с использованием сигнала готовности (в наносекундах)                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| 69-70 | R                                                | Зарезервированы для поддержки перекрытия команд и очередей                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |
| 71    | F                                                | Типовое время от получения команды <i>Packet</i> до освобождения шины (в наносекундах)                                                                                                                                                                                                                                                                                                                                                                                                                                                                       |  |
| 72    | F                                                | Типовое время от получения команды Service до сброса BSY (в напосекупдах)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                    |  |
| 73-74 | R                                                | Зарезервировано                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 75    | F                                                | Глубина очереди команд: биты 15–5—<br>зарезервированы, биты 4–0— максимальная<br>глубина очереди                                                                                                                                                                                                                                                                                                                                                                                                                                                             |  |
| 76-79 | R                                                | Зарезервировано                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |  |
| 80    | F                                                | Номер основной версии интерфейса<br>(если не 0000h или FFFFh):<br>1— ATA-1,<br>2— ATA-2 ит. д.                                                                                                                                                                                                                                                                                                                                                                                                                                                               |  |
| 81    | F                                                | Младший номер версии интерфейса<br>(если не 0000h или FFFFh)                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 |  |
| 82    | F                                                | Поддержка команд и свойств (если слова 82 и 83 не равны 0000h или FFFFh): Бит 15 — не используется Бит 14 — команды Nop Бит 13 — команды Read Buffer Бит 12 — команды Write Buffer Бит 11 — не используется Бит 10 — ограничение доступного пространства Бит 9 — команда Device Reset Бит 8 — вырабатывание прерывания во время команды Service Бит 7 — прерывание по освобождению шины Бит 6 — кэширование с упреждающим чтением Бит 5 — команда Packet Бит 3 — управление эпергопотреблением Бит 2 — смена носителя Бит 1 — команды Security Бит 0 — SMART |  |

| Таблица 6. | блица 6.12 (продолжение) |                                                                                                                                                                                                   |  |
|------------|--------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Слово      | F/V                      | Назначение                                                                                                                                                                                        |  |
| 83         | F                        | Поддержка команд и свойств (как и слово 82): Бит 15 = 0 Бит 14 = 1 Биты 13-5 — зарезервированы Бит 4 — уведомление о смене носителя Биты 3-1 — зарезервированы Бит 0 — команда Download Microcode |  |
| 84         | F                        | Поддержка команд и свойств (если слова 82, 83 и 84 не равны 0000h или FFFFh): Бит 15 = 0 Бит 14 = 1 Биты 13-0 — зарезервированы                                                                   |  |
| 85-87      | F                        | Разрешенные команды и свойства — поля и правила аналогичны словам 82–84                                                                                                                           |  |
| 88         | R                        | Режим Ultra DMA: Биты 15-11 — зарезервированы Биты 10-8 — активный режим Ultra DMA: бит 8-1 — Mode 0, бит 9-1 — Mode 1 и т. д. Единичное значение может иметь только один бит                     |  |
|            | R<br>V                   | Биты 7-3 — зарезервированы Биты 2-0 — поддерживаемые режимы                                                                                                                                       |  |

ы е режимы олиночного обмена DMA: бит 0=1 - Mode 0. бит 1=1 — Mode 1 и т. д. 89-126 R Зарезервировано 127 R Биты 15-2 — зарезервированы F Биты 1-0 — уведомление о смене носителя: 00 — не поддерживается, 01 — поддерживается,

1х — зарезервированы 128 v Состояние защиты: Биты 15-9 - зарезервированы Бит 8 — уровень защиты: 0 — высокий. 1 — максимальный Биты 7-6 — зарезервированы Бит 5: 1 — поддержка расширенного защитного стирания Бит 4: 1 - счетчик попыток иссяк

Бит 3: 1 — команды защиты блоки рованы

| <u></u>                                                                   | -7                                                         |                                                                                                                                                                                                                                                                                                                                    |
|---------------------------------------------------------------------------|------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
|                                                                           |                                                            | Бит 2: 1— устройство заблокировано<br>Бит 1: 1— защита разрешена<br>Бит 0: 1— защита поддерживается                                                                                                                                                                                                                                |
| 129-159                                                                   | X                                                          | Специфично                                                                                                                                                                                                                                                                                                                         |
| 160-255                                                                   | R                                                          | Зарезервировано                                                                                                                                                                                                                                                                                                                    |
| признаки                                                                  | коман                                                      |                                                                                                                                                                                                                                                                                                                                    |
|                                                                           |                                                            | <ul><li>И — является указанием на использование<br/>ltra DMA для обмена данными.</li></ul>                                                                                                                                                                                                                                         |
|                                                                           |                                                            | <ul> <li>– является признаком возможности пере-<br/>ся выполнения.</li> </ul>                                                                                                                                                                                                                                                      |
| передавае<br>команда і<br>руется. Ес<br>ет лимит,<br>или мены<br>восприни | мых по<br>не пред<br>сли обы<br>значен<br>пе лим<br>мается | CL содержат лимит счетчика байт данных, о каждому введению DRQ в режиме PIO. Если дусматривает обмена данными, поле игнорищее число требуемых байт данных превышание лимита задается четным. Если оно равно ита, лимит нечетен. Значение лимита FFFFh устройством как FFFEh. Лимит счетчика, к передаче пакета отношения не имеет. |
| устройств                                                                 | в, подд                                                    | ользуется только для выбора устройства. Для ерживающих очереди команд, биты [7:3] режат тег ( <i>Tag</i> ).                                                                                                                                                                                                                        |
| После под<br>жать след                                                    |                                                            | оманды регистр SC кроме тега будет содере<br>е биты:                                                                                                                                                                                                                                                                               |
| <b>≋</b> Бит 2                                                            | REL                                                        | (Release) — признак освобождения шины (для                                                                                                                                                                                                                                                                                         |

Назначение

Ж Бит 1 — I/O (Input/Output) — указатель направления передачи данных (0 — передача к устройству, 1 — к хосту).
 Ж Бит 0 — C/D (Command/Data) — признак передачи команды (1) или данных (0).

перекрывающихся команд).

ды (1) или данных (0).
В регистре состояния некоторые биты получают новое на-

В регистре состояния некоторые биты получают новое назначение:

Бит 5 — DMRDY (DMA Ready) — при DRQ=1 использует-

ся как признак готовности к обмену в режиме (Ultra)

Виты 1, 2 не используются.
 Вит 0 — СНК (Check) — признак ошибки.
 Остальные биты сохранили обычное назначение.
 После подачи команды Packet хост определяет состояние устройства, прочитав его регистры. Возможны следующие варианты:

DMA. При DRQ=0 является признаком отказа устрой-

Бит 4 - SERV (Service) — признак готовности к обслужи-

ства DF (Device Fault).

ванию команды, освободившей шину.

- Ожидание команды Packet: в регистре SC биты C/D=1, I/O=0, REL=0, поле Tag содержит ранее установленное значение. В регистре состояния BSY=0, DMRDY=0, CHK=0, DRQ=1, бит SERV может указывать на наличие команды, ожидающей обслуживания.
- Передача данных: в регистре SC биты C/D=0, REL=0, I/O
   указывает на направление передачи. Регистры CH, CL при
   использовании PIO содержат счетчик байт данных. В регистре состояния BSY=0, DRQ=1, CHK=0, DMRDY указывает на использование DMA, бит SERV может указывать
   использование DMA, бит SERV может указывать
   использование DMA.
- вает на использование DMA, бит SERV может указывать на наличие команды, ожидающей обслуживания.

  Освобождение шины: в регистре SC биты C/D=0, I/O=0, REL=1, поле Tag содержит тег. В регистре состояния BSY=0, DMRDY=0, CHK=0, DRQ=0, бит SERV может указывать на наличие команды, ожидающей обслуживания.
- Запрос обслуживания: в регистре SC биты C/D=0, I/O=0, REL=1, поле Tag содержит тег. В регистре состояния BSY=0, DMRDY=0, CHK=0, DRQ=0, бит SERV=1.
   Успешное завершение: в регистре SC биты C/D=1, I/O=1, REL=0, поле Tag содержит тег. В регистре состояния
- нес=0, поле тад содержит тег. в регистре состояния BSY=0, DRDY=1, CHK=0, DRQ=0, бит SERV может указывать на наличие команды, ожидающей обслуживания. Завершение с ошибкой (только после передачи последнего
  - байта пакета): в регистре *SC* биты *C/D*=1, *I/O*=1, *REL*=0, поле *Tag* содержит тег. В регистре состояния *BSY*=0, *DRDY*=1, *DRQ*=0, *DF*=1 при отказе устройства, *CHK*=1, если

регистр ошибок содержит код ошибки, бит SERV может указывать на наличие команды, ожидающей обслуживания. В регистре ошибок биты 0 и 1 трактуются в зависимости от команды, бит 2 — признак отвергнутой команды (ABRT), биты [7:4] могут содержать уточненное состояние.

Структуру командного пакета см. в 5.5. При любой длине блока дескрипторов, определяемой кодом команды (нулевой байт пакета), передаваемый пакет имеет длину 16 байт, но используется только указанное количество байт. Систему команд и структуру пакетов стандарт ATA/ATAPI-4 не описывает, но для каждого класса устройств существует стандартизованный набор команд с определенной структурой

# 6.8. Адаптеры шины АТА и категории устройств IDE

пакетов.

лов шины и дешифратор зоны адресов. Все регистры контроллера и схемы кодирования размещены в самом устройстве IDE. Шина ATA требует выделения системных ресурсов — двух областей портов ввода/вывода и линии прерывания; дополнительно может использоваться канал DMA. Интерфейсу ATA первого канала выделили ресурсы, ранее использовавшиеся контроллером жестких дисков. Второму каналу

Простейший *адаптер ATA* содержит только буферы сигна-

дополнительно может использоваться канал DMA. Интерфейсу ATA первого канала выделили ресурсы, ранее использовавшиеся контроллером жестких дисков. Второму каналу назначили ресурсы альтернативного контроллера жестких дисков. Позже определили ресурсы еще для двух каналов (табл. 6.13). Традиционному контроллеру жестких дисков выделялся канал DMA3, но он является 8-битным, в то время как шина ATA требует 16-битного канала DMA. Производительности стандартных каналов DMA для шины ATA явно недостаточно. На системных платах с шиной PCI стандартом является установка двухканального адаптера, занимающего ресурсы каналов 1 и 2. Этот адаптер обеспечивает

мающего ресурсы каналов 1 и 2. Этот адаптер обеспечивает шинам ATA 16-битные каналы DMA, поддерживающие высокоскоростные режимы обмена (см. табл. 6.11). В идеальном варианте двухканальные контроллеры имеют шины, полностью изолированные друг от друга буферными и логическими схемами. В самом дешевом варианте они ис-

яние паразитных параметров): *суммарная длина* обоих шлейфов не должна превышать 46 см, а *суммарная емкость* каждой линии со всеми устройствами не должна превышать 35 пФ. Иначе на высокоскоростных режимах обмена возможны *неконтролируемые искажения* передаваемых данных.

пользуют общие буферы для линий данных и управляющих сигналов и отдельные только для некоторых сугубо индивидуальных сигналов. С точки зрения логики, здесь все в порядке, но следует учитывать нагрузочную способность (вли-

# Теблица 6.13 Системные ресурсы каналов АТА

| Канал | CS0       | CS1       | IRQ       |
|-------|-----------|-----------|-----------|
| 1     | 1F0h-1F7h | 3F6h-3F7h | 14        |
| 2     | 170h-177h | 376h-377h | 15 или 10 |
| 3     | 1E8h-1Efh | 3EEh-3Efh | 12 или 11 |
| 4     | 168h-16Fh | 36Eh-36Fh | 10 или 9  |

4 168h-16Fh 36Eh-36Fh 10 или 9

Поскольку скорость программного обмена задается хост-адаптером, интересно индивидуальное программирование PIO Моdе для каждого канала/устройства. Ряд чипсетов этого не допускает и при инициализации назначает общий минималь-

Моdе для каждого канала/устройства. Ряд чипсетов этого не допускает и при инициализации назначает общий минимальный режим. В результате подключение «тихоходного» устройства замедляет обмен быстрого соседнего устройства. Адаптеры ATA часто размещают на звуковых картах для под-

ключения накопителей CD-ROM. По умолчанию им назначают ресурсы каналов 3 или 4. К этим каналам можно подключать винчестеры, но будет ли их там искать BIOS во время POST — вопрос. Современные версии BIOS позволяют хранить конфигурационные параметры четырех жестких дисков, более старые версии — двух. Четыре канала ATA физически позволяют подключить до восьми накопителей, но работа с

позволяют подключить до восьми накопителеи, но работа с ними лимитирована программными ограничениями. Расширенные адаптеры могут иметь аппаратные средства поддержки высокоэффективных режимов передачи (PIO, DMA, Bus Master), буферные регистры записи и собствен-

ную кэш-память. Сложные адаптеры аппаратно поддерживают «зеркальные» диски. Некоторые адаптеры позволяют соединять несколько физических дисков в один логический

Существуют гибридные адаптеры для подключения АТА HDD к шинам XT и MCA или, например, к LPT-порту. Интерфейс АТА позволяет подключать устройства различ-

на уровне вызовов BIOS (в настоящее время актуальнее об-

ратная задача).

вок чередования и смещения.

нейному (LBA) адресу).

ных категорий, отличающихся «уровнем интеллекта» встроенного контроллера. Первые дисковые накопители IDE относятся к категории неинтеллектуальных устройств -Non-Intelligent IDE. Они не выполняли трансляцию нумера-

ции секторов — их логические параметры совпадали с физическими. Команды идентификации устройства и установки параметров не выполнялись. Дефектные блоки, отмеченные в заводском списке, были видны пользователю. Низкоуровневое форматирование выполнялось непосредственно по команде, так что неудачное форматирование могло понизить производительность из-за нарушения оптимальных устано-

Более интеллектуальные устройства — Intelligent ATA IDE. Они способны выполнять расширенные АТА-команды идентификацию устройства и установку параметров. Поддерживается трансляция физических параметров в логические. Дефектные сектора скрыты от пользователя (до исчерпания резерва). Низкоуровневое форматирование возможно

только при установке логической геометрии, совпадающей с физической. Однако форматирование опять-таки «сносит» заводскую оптимизацию. Для ускорения обмена эти устройства поддерживают блочные режимы передачи Read Multiple и Write Multiple, а также высокоскоростные режимы обмена PIO и DMA.

К следующей категории относятся устройства с зонным форматом записи — Intelligent Zoned Recording IDE. Поскольку

они имеют различное количество секторов на разных треках (для повышения плотности хранения), трансляция геометрии является для них обязательной (спецификация АТА не предусматривает сообщения устройством способа разбиения на зоны и формата каждой зоны, так что обращаться к ним можно только по логическому трехмерному (CHS) или лиметров (SMART), температурная коррекция системы позиционирования, поддержка управления энергопотреблением и различные усовершенствования, направленные на повышение производительности.

6.9. Конфигурирование устройств

корректно сконфигурированы. Конфигурирование подразумевает выбор типа интерфейса и определение адреса устройства. Тип интерфейса — XT или AT — определяется моделью накопителя. В изделиях фирмы Seagate тип обозначается последней буквой в шифре модели: А — ATA (16 бит), X — для XT (8 бит), а сочетание AX означает возможность вы-

Устройства IDE отличаются также по интеллектуальности контроллера: автоматический мониторинг внутренних пара-

# Устройства АТА перед подключением к шине должны быть

бора АТ/ХТ с помощью джампера. Существует два способа задания адреса устройства — с помощью кабельной выборки или явным заданием адреса на каждом из устройств. Режим кабельной выборки включается перемычкой CS (Cable Select — кабельная выборка). В этом случае оба устройства на шине конфигурируются одинаково - в режим CS, а адрес устройства определяется его положением на специальном кабеле-шлейфе (рис. 6.2). Кабельная выборка будет работать, если она поддерживается и задана на всех устройствах канала, включая хост-адаптер, который обеспечивает заземление контакта 28. При этом способе задания адресов исключается синхронизация шпинделей накопителей (актуально в RAID-массивах) через тот же провод контакта 28. Кабельная выборка применяется редко. Ее условное преимущество — унификация конфигурирования устройств, а недостаток — привязка физического положения устройств к кабелю — ведущее устройство должно быть ближе к адаптеру, чем ведомое. Возможно подключе-

ние адаптера к среднему разъему, а устройств — к крайним,

Более распространен режим явной адресации, при котором используется обычный «прямой» кабель (см. рис. 6.1). В этом случае перемычка CS не устанавливается, а адрес устрой-

но это не всегда удобно.

ства задается перемычками, состав которых варьируется. В принципе, достаточно лишь указать устройству его номер (0/1), но в устройствах, разработанных до стандарта АТА,

следующие джамперы:

ведущему устройству «подсказывали» о наличии ведомого (по интерфейсу АТА оно могло бы это определить само по сигналу DASP#). Итак, на устройствах IDE можно увидеть

адреса. Если на шине присутствует одно устройство, оно должно быть сконфигурировано как ведущее. Если на шине два устройства — одно должно быть ведущим, другое — ведомым. Иногда джампер обозначается как «С/D» (диск C:/диск D:), но для второго канала IDE такое название некорректно. Когда появились первые IDE-диски

M/S (Master/Slave — ведущее/ведомое) — переключатель

емкостью 1 Гбайт, для преодоления барьера в 504 Мбайт некоторые модели допускали конфигурирование в виде двух устройств (0 и 1) половинной емкости. В таком режиме на их IDE-шлейф второе физическое устройство подключать нельзя. SP (Slave Present), DSP (Drive Slave Present), «Master but

Slave is not ATA-compatible», «Master but Slave uses only PDIAG-signal» — устанавливается на ведущем устройстве для указания на присутствие ведомого. Если переключатель установлен, а ведомое устройство не подключено, POST даст сообщение об ошибке. Джампер применяется для дисков, не использующих сигнал DASP#.

ACT (Drive Active) — устанавливается на Master (встречается редко). Для полностью *ATA-совместимых* дисков перемычка ставится

только на ведомое устройство, а его присутствие ведущее определит автоматически. Разобраться с джамперами старых устройств трудно, если нет документации. У современных устройств лишние джамперы

упразднили, а существующие комментируются на наклейкешильдике. Если джамперы устанавливаются рядом с интерфейсным разъемом, вероятно, они расположены в соответствии со стандартом АТА (рис. 6.4). Здесь буквой к обозначены по-

зиции ключевых (пропущенных) выводов, контакты 1-40 ис-

пользуются для интерфейса, а контакты A-H — для установки джамперов (табл. 6.14).



**Рис. 6.4.** Джамперы на разъемах интерфейса АТА: *a* — SFF8212, *б* — SFF8057, *в* — SFF8058

#### Таблица 6.14. Установка джамперов

| Выборка                  | SFF8212 | SFF8057  | SFF8058 |
|--------------------------|---------|----------|---------|
| Используемые контакты    | AD      | ЕН       | AF      |
| Кабельная выборка        | B-D     | E-F      | A-B     |
| Master                   | -       | G–H      | E-F     |
| Master при наличии Slave | _       | G-H, E-F | E-F     |
| Slave                    | A-B     | _        | C-D     |



Следует учитывать, что перестановка джамперов часто воспринимается устройством только по включении питания. Кроме того, установка на один шлейф двух разнотипных не-ATA-устройств часто невозможна.

## 7. Последовательные шины

Последовательные шины позволяют объединять множество устройств, используя всего 1–2 пары проводов. При этом достигается пропускная способность от 100 кбит/с для шины ACCESS. Виз до 400 Мбит/с у FireWire. Функциональные возможности этих шин гораздо шире, чем у традиционных интерфейсов локальных сетей — USB и FireWire способны передавать изохронный трафик аудио- и видеоданных.

#### 7.1. Шина USB

USB (Universal Serial Bus — универсальная последовательная шина) является промышленным стандартом расширения архитектуры PC, ориентированным на интеграцию с телефонией и устройствами бытовой электроники. Версия 1.0 была опубликована в январе 1996 года. Архитектура USB определяется следующими критериями:

- Легко реализуемое расширение периферии РС.
- Дешевое решение, поддерживающее скорость передачи до 12 Мбит/с.
- Полная поддержка в реальном времени передачи аудиои (сжатых) видеоданных.
- Гибкость протокола смешанной передачи изохронных данных и асинхронных сообщений.
- ₩ Интеграция с выпускаемыми устройствами.
- Обеспечение стандартного интерфейса, способного быстро завоевать рынок.

С точки зрения конечного пользователя, привлекательны следующие черты USB:

Простота кабельной системы и подключений.

устройств с драйверами и конфигурирование. Возможность динамического подключения и конфигурирования ПУ. С середины 1996 года выпускаются РС со встроенным кон-

Скрытие подробностей электрического подключения от

Самоидентифицирующиеся ПУ, автоматическая связь

троллером USB, реализуемым чипсетом. Ожидается появление модемов, клавиатур, сканеров, динамиков и других устройств ввода/вывода с поддержкой USB, а также мониторов с USB-адаптерами — они будут играть роль хабов для подключения других устройств.

# 7.1.1. **CTDYKTYPA USB**

конечного пользователя.

#### USB обеспечивает одновременный обмен данными между хост-компьютером и множеством периферийных устройств (ПУ). Распределение пропускной способности шины между ПУ планируется хостом и реализуется им с помощью посылки маркеров. Шина позволяет подключать, конфигурировать, использовать и отключать устройства во время работы хоста и самих устройств.

Ниже приводится авторский вариант перевода терминов спецификации «Universal Serial Bus Specification. Revision 1.0, January 15, 1996», опубликованной Сомрад, DEC, IBM, Intel, Microsoft, NEC и Northern Telecom. Более подробную и оперативную информацию можно найти по адpecy: http://www.usb.org.

Устройства (Device) USB могут являться хабами, функциями или их комбинацией. Хаб (Hub) обеспечивает дополнительные точки подключения устройств к шине. Функции

(Function) USB предоставляют системе дополнительные возможности, например подключение к ISDN, цифровой джойстик, акустические колонки с цифровым интерфейсом и т. п. Устройство USB должно иметь интерфейс USB, обеспечи-

вающий полную поддержку протокола USB, выполнение

стандартных операций (конфигурирование и сброс) и предоставление информации, описывающей устройство. Мноне пирамиды устройств и хабов. Хост-контроллер интегрируется с корневым хабом (Root Hub), обеспечивающим одну или несколько точек подключения — портов. Контроллер USB, входящий в состав чипсетов, обычно имеет встроенный двухпортовый хаб. Логически устройство, подключенное к любому хабу USB и сконфигурированное (см. ниже), может рассматриваться как непосредственно подключенное к хост-контроллеру.

Функции представляют собой устройства, способные пере-

гие устройства, подключаемые к USB, имеют в своем составе и хаб, и функции. Работой всей системы USB управляет хост-контроллер (Host Controller), являющийся программно-

Физическое соединение устройств осуществляется по топологии многоярусной звезды. Центром каждой звезды является хаб, каждый кабельный сегмент соединяет две точки — хаб с другим хабом или с функцией. В системе имеется один (и только один) хост-контроллер, расположенный в верши-

аппаратной подсистемой хост-компьютера.

давать или принимать данные или управляющую информацию по шине. Типично функции представляют собой отдельные ПУ с кабелем, подключаемым к порту хаба. Физически в одном корпусе может быть несколько функций со встроенным хабом, обеспечивающим их подключение к одному порту. Эти комбинированные устройства для хоста являются хабами с постоянно подключенными устройствами-функциями.

Каждая функция предоставляет конфигурационную инфор-

мацию, описывающую возможности ПУ и требования к ресурсам. Перед использованием функция должна быть сконфигурирована хостом — ей должна быть выделена полоса в

канале и выбраны опции конфигурации.
Примерами функций являются:

« Указатели — мышь, планшет, световое перо.

- Устройства ввода клавиатура или сканер.
- Устройство вывода принтер, звуковые колонки (циф-
- ровые). Телефонный адаптер ISDN.

Хаб является кабельным концентратором. Точки подключения называются *портами* хаба. Каждый хаб преобразует одну точку подключения в их множество. Архитектура допускает соединение нескольких хабов.

У каждого хаба имеется один восходящий порт (Upstream Port), предназначенный для подключения к хосту или хабу

верхнего уровня. Остальные порты являются нисходящими (Downstream Ports), предназначенными для подключения функций или хабов нижнего уровня. Хаб может распознать подключение устройств к портам или отключение от них и управлять подачей питания на их сегменты. Каждый из пор-

*Хаб* — ключевой элемент системы PnP в архитектуре USB.

тов может быть разрещен или запрещен и сконфигурирован на полную или ограниченную скорость обмена. Хаб обеспечивает изоляцию сегментов с низкой скоростью от высокоскоростных.

Хабы могут управлять подачей питания на нисходящие порты; предусматривается установка ограничения на ток, потребляемый каждым портом.

Хост физическое устройство функций

USB Logical Devica

> USB Bus Interface

**Уровень** 

устройств USB

**Уровень** 

интерфейса шины USB

Логические связи

Рис. 7.1. Взаимодействие компонентов USB

Действительные связи

USB System

USB Host

стемную и ПО устройства. Каждая часть отвечает только за определенный круг задач, логическое и реальное взаимодействие между ними иллюстрирует рис. 7.1. В рассматриваемую структуру входят следующие элементы:

Система USB разделяется на три уровня с определенными правилами взаимодействия. Устройство USB содержит интерфейсную часть, часть устройства и функциональную часть. Хост тоже делится на три части — интерфейсную, си-

 $\Phi$ изическое устройство USB — устройство на шине, выполняющее функции, интересующие конечного пользо-

вателя. Client  $SW - \Pi O$ , соответствующее конкретному устрой-

ству, исполняемое на хост-компьютере. Может являться составной частью ОС или специальным продуктом.

USB System SW — системная поддержка USB, независимая от конкретных устройств и клиентского ПО. USB Host Controller — аппаратные и программные средства для подключения устройств USB к хост-компьютеру.

#### Физический интерфейс

Стандарт USB определяет электрические и механические спецификации шины. Информационные сигналы и питающее напряжение 5 В передаются по четырехпроводному кабелю. Используется диф-

ференциальный способ передачи сигналов D+ и D- по двум проводам. Уровни сигналов передатчиков в статическом режиме должны быть ниже 0,3 В (низкий уровень) или выше 2,8 В (высокий уровень). Приемники выдерживают входное

напряжение в пределах - 0,5...+3,8 В. Передатчики должны уметь переходить в высокоимпедансное состояние для двунаправленной полудуплексной передачи по одной паре проводов.

Передача по двум проводам в USB не ограничивается дифференциальными сигналами. Кроме дифференциального

приемника каждое устройство имеет линейные приемники сигналов D+ и D-, а передатчики этих линий управляются индивидуально. Это позволяет различать более двух состоя-

условии, что на одной из них потенциал выще порога срабатывания V<sub>SE</sub>. Состояние, при котором на обоих входах D+ и D- присутствует низкий уровень, называется *линейным ну*лем (SEO — Single-Ended Zero). Интерфейс определяет следующие состояния: Data I State и Data K State — состояния передаваемого бита (или просто Ј и К), определяются через состояния

ний линии, используемых для организации аппаратного интерфейса. Состояния Diff0 и Diff1 определяются по разности потенциалов на линиях D+ и D- более 200 мВ при

*Idle State* — пауза на шине. Resume State — сигнал «пробуждения» для вывода устрой-88 ства из «спящего» режима.

Start of Packet (SOP) — начало пакета (переход из Idle State \*\* BK).

 $End\ of\ Packet\ (EOP)\ -$  конец пакета. Disconnect — устройство отключено от порта.

Diff0 и Diff1.

*Connect* — устройство подключено к порту. \*

Reset — сброс устройства.

и линейных сигналов; для полной и низкой скоростей состояния Diff0 и Diff1 имеют противоположное назначение. В декодировании состояний Disconnect, Connect и Reset учитывается время нахождения линий (более 2,5 мс) в опреде-

Состояния определяются сочетаниями дифференциальных

ленных состояниях. Шина имеет два режима передачи. Полная скорость передачи сигналов USB составляет 12 Мбит/с, низкая — 1,5 Мбит/с. Для

полной скорости используется экранированная витая пара с импедансом 90 Ом и длиной сегмента до 5 м, для низкой невитой неэкранированный кабель до 3 м. Низкоскоростные кабели и устройства дешевле высокоскоростных. Одна и та

же система может одновременно использовать оба режима; переключение для устройств осуществляется прозрачно. Низкая скорость предназначена для работы с небольшим

количеством ПУ, не требующих высокой скорости.

Скорость, используемая устройством, подключенным к конкретному порту, определяется хабом по уровням сигналов на линиях D+ и D-, смещаемых нагрузочными резисторами R2 приемопередатчиков (см. рис. 7.2 и 7.3).

Сигналы синхронизации кодируются вместе с данными по методу NRZI (Non Return to Zero Invert), его работу иллюст-

рирует рис. 7.4. Каждому пакету предшествует поле синхронизации *SYNC*, позволяющее приемнику настроиться на частоту передатчика.

Кабель также имеет линии VBus и GND для передачи питающего напряжения 5 В к устройствам. Сечение проводников выбирается в соответствии с длиной сегмента для обеспечения гарантированного уровня сигнала и питающего напряжения.



Рис. 7.2. Подключение полноскоростного устройства



Рис. 7.3. Подключение низкоскоростного устройства



Рис. 7.4. Кодирование данных по методу NRZI

Стандарт определяет *два типа разъемов* (см. табл. 7.1 и рис. 7.5).

#### Таблица 7.1. Назначение выводов разъема USB

| Контакт | Цепь | Контакт | Цепь |
|---------|------|---------|------|
| 1       | VBus | 3       | D+   |
| 2       | D-   | 4       | GND  |

Разъемы типа «А» применяются для подключения к хабам (Upstream Connector). Вилки устанавливаются на кабелях, не отсоединяемых от устройств (например, клавиатура, мышь и т. п.). Гнезда устанавливаются на нисходящих портах (Downstream Port) хабов.

Разъемы типа «В» (Downstream Connector) устанавливаются на устройствах, от которых соединительный кабель может отсоединяться (принтеры и сканеры). Ответная часть (вилка) устанавливается на соединительном кабеле, противоположный конец которого имеет вилку типа «А».

Разъемы типов «А» и «В» различаются механически (рис. 7.5), что исключает недопустимые петлевые соединения портов хабов. Четырехконтактные разъемы имеют ключи, исключающие неправильное присоединение. Конструкция разъемов обеспечивает позднее соединение и раннее отсоединение сигнальных цепей по сравнению с питающими. Для распознавания разъема USB на корпусе устройства



**Рис. 7.5.** Гнезда USB: a — типа «A»,  $\delta$  — типа «B», b — символическое обозначение

Питание устройств USB возможно от кабеля (Bus-Powered Devices) или от собственного блока питания (Self-Powered

портам. При некоторых ограничениях топологии допускается применение хабов, питающихся от шины. На рис. 7.6 приведен пример схемы соединения устройств USB. Здесь клавиатура, перо и мышь могут питаться от шины.

Хаб / «функция» Хаб / «функция» Хост-хаб Монитор РС

Devices). Хост обеспечивает питанием непосредственно подключенные к нему ПУ. Каждый хаб, в свою очередь, обеспечивает питание устройств, подключенных к его нисходящим



#### Модель передачи данных

Каждое устройство USB представляет собой набор независимых конечных точек (Endpoint), с которыми хост-контроллер обменивается информацией. Конечные точки описываются следующими параметрами:

- требуемой частотой доступа к шине и допустимыми задержками обслуживания;
- требуемой полосой пропускания канала;
- ₩ номером точки;
- требованиями к обработке ошибок;
- максимальными размерами передаваемых и принимаемых пакетов;

» направлением обмена (для сплошного и изохронного об-

типом обмена:

менов).

Каждое устройство обязательно имеет конечную точку с но-

мером 0, используемую для инициализации, общего управления и опроса его состояния. Эта точка всегда сконфигурирована при включении питания и подключении устройства к шине. Оно поддерживает передачи типа «управ-

ление» (см. далее).

Кроме нулевой точки, устройства-функции могут иметь дополнительные точки, реализующие полезный обмен данными. Низкоскоростные устройства могут иметь до двух до-

полнительных точек, полноскоростные — до 16 точек ввода и 16 точек вывода (протокольное ограничение). Точки не могут быть использованы до их конфигурирования (уста-

новления согласованного с ними канала). Каналом (Pipe) в USB называется модель передачи данных между хост-контроллером и конечной точкой (Endpoint) устройства. Имеются два типа каналов: потоки (Stream) и сообщения (Message). Поток доставляет данные от одного конца канала к другому, он всегда однонаправленный. Один и тот же номер конечной точки может использоваться для двух поточных каналов — ввода и вывода. Поток может реализовывать следующие типы обмена: сплошной, изохронный и прерывания. Доставка всегда идет в порядке «первым вошел — первым вышел» (FIFO); с точки зрения USB, данные потока неструктурированы. Сообщения имеют формат, определенный спецификацией USB. Хост посылает запрос к конечной точке, после которого передается (принимается) пакет сообщения, за которым следует пакет с информацией состояния конечной точки. Последующее сообщение нор-

С каналами связаны характеристики, соответствующие конечной точке (полоса пропускания, тип сервиса, размер буфера

используется только обмен типа «управление».

мально не может быть послано до обработки предыдущего, но при отработке ошибок возможен сброс необслуженных сообщений. Двухсторонний обмен сообщениями адресуется к одной и той же конечной точке. Для доставки сообщений

и т. п.). Каналы организуются при конфигурировании устройств USB. Для каждого включенного устройства существует канал сообщений (Control Pipe 0), по которому передается информация конфигурирования, управления и состояния. Типы передачи данных

ленные режимы связи. Передача данных производится между ПО хоста и конечной точкой устройства. Устройство может иметь несколько конечных точек, связь с каждой из них

USB поддерживает как однонаправленные, так и двунаправ-

(канал) устанавливается независимо. Архитектура USB допускает четыре базовых типа передачи ланных:

- Управляющие посылки (Control Transfers), используемые для конфигурирования во время подключения и в процессе
- работы для управления устройствами. Протокол обеспечивает гарантированную доставку данных. Длина поля данных управляющей посылки не превышает 64 байт на
- полной скорости и 8 байт на низкой. Сплошные передачи (Bulk Data Transfers) сравнительно больших пакетов без жестких требований ко времени до-
- ставки. Передачи занимают всю свободную полосу пропускания шины. Пакеты имеют поле данных размером 8, 16, 32 или 64 байт. Приоритет этих передач самый низкий, они могут приостанавливаться при большой загрузке шины. Допускаются только на полной скорости
- передачи. Прерывания (Interrupt) — короткие (до 64 байт на полной скорости, до 8 байт на низкой) передачи типа вводимых символов или координат. Прерывания имеют спонтанный
- характер и должны обслуживаться не медленнее, чем того требует устройство. Предел времени обслуживания устанавливается в диапазоне 1-255 мс для полной скорости
- и 10-255 мс для низкой. Изохронные передачи (Isochronous Transfers) — непрерывные передачи в реальном времени, занимающие предварительно согласованную часть пропускной способности шины и имеющие заданную задержку доставки. В случае

обнаружения ошибки изохронные данные передаются без повтора — недействительные пакеты игнорируются. Пример — цифровая передача голоса. Пропускная способность определяется требованиями к качеству передачи, а задержка доставки может быть критичной, например, при реализации телеконференций.

Полоса пропускания шины делится между всеми установленными каналами. Выделенная полоса закрепляется за каналом, и если установление нового канала требует такой

полосы, которая не вписывается в уже существующее распределение, запрос на выделение канала отвергается. Архитектура USB предусматривает внутреннюю буферизацию всех устройств, причем чем большей полосы пропускания требует устройство, тем больше должен быть его буфер. USB должна обеспечивать обмен с такой скоростью, чтобы задержка данных в устройстве, вызванная буферизацией, не

Изохронные передачи классифицируются по способу синхронизации конечных точек — источников или получателей данных — с системой: различают асинхронный, синхронный и адаптивный классы устройств, каждому из которых соответствует свой тип канала USB.

Все обмены (транзакции) по USB состоят из трех пакетов.

превышала нескольких миллисекунд.

#### Протокол

Каждая транзакция планируется и начинается по инициативе контроллера, который посылает пакет-маркер (Token Packet). Он описывает тип и направление передачи, адрес устройства USB и номер конечной точки. В каждой транзакции возможен обмен только между адресуемым устройством (его конечной точкой) и хостом. Адресуемое маркером устройство распознает свой адрес и готовится к обмену. Источник данных (определенный маркером) передает пакет данных (или уведомление об отсутствии данных, предназначенных для передачи). После успешного приема пакета приемник данных

посылает *пакет подтверждения* (Handshake Packet). Планирование транзакций обеспечивает управление поточными каналами. На аппаратном уровне использование от-

Устойчивость к ошибкам обеспечивают следующие свойства USB:

Высокое качество сигналов, достигаемое благодаря дифференциальным приемникам/передатчикам и экранированным кабелям.

разнородных потоков данных.

каза от транзакции (NAck) при недопустимой интенсивности передачи предохраняет буферы от переполнения сверху и снизу. Маркеры отвергнутых транзакций повторно передаются в свободное для шины время. Управление потоками позволяет гибко планировать обслуживание одновременных

конфигурирование ресурсов на системном уровне.

« Самовосстановление протокола с тайм-аутом при потере пакетов.

Обнаружение подключения и отключения устройств и

Управление потоком для обеспечения изохронности и

Защита полей управления и данных CRC-кодами.

- управления аппаратными буферами.

  Ж Независимость функций от неудачных обменов с другими функциями.

  Для обнаружения ошибок передачи каждый пакет имеет кон-
- Для обнаружения ошибок передачи каждый пакет имеет контрольные поля CRC-кодов, позволяющие обнаруживать все одиночные и двойные битовые ошибки. Аппаратные средства обнаруживают ошибки передачи, а контроллер автоматически производит трехкратную попытку передачи. Если повторы безуспешны, сообщение об ошибке передается клиентскому ПО.

#### Форматы пакетов

88

Байты передаются по шине последовательно, начиная с младшего бита. Все посылки организованы в пакеты. Каждый

пакет начинается с поля синхронизации Sync, которое пред-

ставляется последовательностью состояний KJKJKJKK (кодированную по NRZI), следующую после состояния Idle. Последние два бита (КК) являются маркером начала пакета SOP, используемым для идентификации первого бита идентификатора пакета PID. Идентификатор пакета является 4-бит-

полем *PID[3:0]*, идентифицирующим (табл. 7.2), за которым в качестве контрольных следуют те же 4 бита, но инвертированные.

Содержимое и назначение

#### Таблица 7.2. Типы пакетов и их идентификаторы PID

PID[3:0]

MMR PID

PRE

Special

1100

Tun PID

| Token     | 001            | 0001         | Адрес функции и номер конечной точки — маркер транзакции функции                                                                                                                                                      |
|-----------|----------------|--------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Token     | IN             | 1001         | Адрес функции и номер конечной точки — маркер транзакции хоста                                                                                                                                                        |
| Token     | SOF            | 0101         | Маркер начала кадра                                                                                                                                                                                                   |
| Token     | SETUP          | 1101         | Адрес функции и номер конечной точки — маркер транзакции с управляющей точкой                                                                                                                                         |
| Data      | Data0<br>Data1 | 0011<br>1011 | Пакеты данных с четным и нечетным PID чередуются для точной идентификации подтверждений                                                                                                                               |
| Handshake | Ack            | 0010         | Подтверждение безошибочного приема пакета                                                                                                                                                                             |
| Handshake | NAK            | 1010         | Приемник не сумел принять или передатчик не сумел передать данные. Может использоваться для управления потоком данных (неготовность). В транзакциях прерываний является признаком отсутствия необслуженных прерываний |
| Handshake | STALL          | 1110         | Конечная точка требует вмеша-<br>тельства хоста                                                                                                                                                                       |
|           |                |              | <del> </del>                                                                                                                                                                                                          |

В пакетах-маркерах IN, SETUP и OUT следующими являются

Преамбула

скорости

передачи

на

низкой

адресные поля: 7-битный адрес функции и 4-битный адрес конечной точки. Они позволяют адресовать до 127 функций USB (нулевой адрес используется для конфигурирования) и по 16 конечных точек в каждой функции.

В пакете SOF имеется 11-битное поле номера кадра (Frame Number Field), последовательно (циклически) увеличиваемое для очередного кадра. Поле данных может иметь размер от 0 до 1023 целых байт.

Размер поля зависит от типа передачи и согласуется при установлении канала. Поле CRC-кода присутствует во всех маркерах и пакетах дан-

ных, оно защищает все поля пакета, исключая PID. CRC для маркеров (5 бит) и данных (11 бит) подсчитываются по разным формулам.

Каждая транзакция инициируется хост-контроллером посылкой маркера и завершается пакетом квитирования. Последовательность пакетов в транзакциях иллюстрирует рис. 7.7.

Хост-контроллер организует обмены с устройствами согласно

своему плану распределения ресурсов. Контроллер циклически (с периодом 1 мс) формирует кадры (Frames), в которые укладываются все запланированные транзакции. Каждый кадр начинается с посылки маркера SOF (Start Of Frame), который является синхронизирующим сигналом для всех устройств, включая хабы. В конце каждого кадра выделяется интервал времени EOF (End Of Frame), на время которого хабы запрещают передачу по направлению к контроллеру.

Каждый кадр имеет свой номер. Хост-контроллер оперирует 32-битным счетчиком, но в маркере SOF передает только

младшие 11 бит. Номер кадра увеличивается (циклически) во время ЕОГ. Хост планирует загрузку кадров так, чтобы в них всегда находилось место для транзакций управления и прерывания. Свободное время кадров может заполняться сплошными передачами (Bulk Transfers). OUT / SETUP Data Handshake Устройство ждет Хост ждет IN Data Handshake

хост ждет

Рис. 7.7. Последовательности пакетов

Устройство ждет



Рис. 7.8. Поток кадров USB

Для *изохронной передачи* важна синхронизация устройств и контроллера. Есть три варианта:

- синхронизация внутреннего генератора устройства с маркерами SOF;
- подстройка частоты кадров под частоту устройства;
- согласование скорости передачи (приема) устройства с частотой кадров.

Подстройка частоты кадров контроллера возможна, естественно, под частоту внутренней синхронизации только одного устройства. Подстройка осуществляется через механизм обратной связи, который позволяет изменять период кадра в пределах ±1 битового интервала.

#### 7.1.2. Системное конфигурирование

USB поддерживает динамическое подключение и отключение устройств. Нумерация устройств шины является постоянным процессом, отслеживающим изменения физической топологии.

Все устройства подключаются через порты хабов. Хабы определяют подключение и отключение устройств к своим портам и сообщают состояние портов при запросе от контроллера. Хост разрешает работу порта и адресуется к устройству через канал управления, используя нулевой адрес — USB Default Address. При начальном подключении или после сброса все устройства адресуются именно так.

Хост определяет, является новое подключенное устройство хабом или функцией, и назначает ему уникальный адрес USB. Хост создает канал управления (Control Pipe) с этим устройством, используя назначенный адрес и нулевой номер точки назначения.

Если новое устройство является хабом, хост определяет подключенные к нему устройства, назначает им адреса и уста-

цией, уведомление о подключении передается диспетчером USB заинтересованному ПО. Когда устройство отключается, хаб автоматически запрещает соответствующий порт и сообщает об отключении кон-

троллеру, который удаляет сведения о данном устройстве из

навливает каналы. Если новое устройство является функ-

всех структур данных. Если отключается хаб, процесс удаления выполняется для всех подключенных к нему устройств. Если отключается функция, уведомление посылается заинтересованному ПО.

Enumeration), осуществляется динамически по мере их подключения (или включения их питания) без какого-либо вме-

(Bus

к

Нумерация устройств, подключенных

шательства пользователя или клиентского ПО. Процедура нумерации выполняется следующим образом:

1. Хаб, к которому подключилось устройство, информирует хост о смене состояния своего порта ответом на опрос состояния. С этого момента устройство переходит в состояние Attached (подключено), а порт, к которому оно подключилось, в состояние Disabled.

- Хост уточняет состояние порта.
   Узнав порт, к которому подключилось новое устройство, хост дает команду сброса и разрешения порта.
  - хост дает команду сброса и разрешения порта.

    4. Хаб формирует сигнал Reset для данного порта (10 мс) и переводит его в состояние *Enabled*. Подключенное устройство может потреблять от шины ток питания
  - до 100 мА. Устройство переходит в состояние *Powered* (питание подано), все его регистры переводятся в исходное состояние, и оно отзывается на обращение по нулевому адресу.
- 5. Пока устройство не получит уникальный адрес, оно доступно по дежурному каналу, по которому хост-контроллер определяет максимально допустимый размер поля

данных пакета.

Хост сообщает устройству его уникальный адрес, и оно переводится в состояние *Addressed* (адресовано).

6.

8. Исходя из полученной информации, хост конфигурирует все имеющиеся конечные точки данного устройства, которое переводится в состояние *Configured* (сконфигурировано). Теперь хаб позволяет устройству потреблять от шины полный ток, заявленный в конфигурации. Устройство готово.

Когда устройство отключается от шины, хаб уведомляет об

 Хост считывает конфигурацию устройства, включая заявленный потребляемый ток от шины. Считывание мо-

жет затянуться на несколько кадров.

этом хост и работа порта запрещается, а хост обновляет свою текущую топологическую информацию.

7.1.3. Устройства USB — функции и хабы
Возможности шины USB позволяют использовать ее для

подключения разнообразных устройств. Не касаясь «полезных» свойств ПУ, остановимся на их интерфейсной части, связанной с шиной USB. Все устройства должны поддержи-

#### Динамическое подключение и отключение. Эти события отслеживаются хабом, который сообщает о них хост-контроллеру и выполняет сброс подключенного устройства. Устройство после сигнала сброса должно отзываться на нулевой адрес, при этом оно не сконфигурировано и не приостанов-

вать набор общих операций, перечисленных ниже.

лено. После назначения адреса, за которое отвечает хост-контроллер, устройство должно отзываться только на свой уникальный адрес.

Конфигурирование устройств, выполняемое хостом, является необходимым для их использования. Для конфигурирования обычно используется информация, считанная из

вания обычно используется информация, считанная из самого устройства. Устройство может иметь множество интерфейсов, каждому из которых соответствует собственная конечная точка, представляющая хосту функцию устройства. Интерфейс в конфигурации может иметь альтернативные наборы характеристик; смена наборов поддерживается про-

Интерфейс в конфигурации может иметь альтернативные наборы характеристик; смена наборов поддерживается протоколом. Для поддержки адаптивных драйверов дескрипторы устройств и интерфейсов имеют поля класса, подкласса и протокола.

Рабочий ток (не более 500 мА) заявляется в конфигурации, и если хаб не сможет обеспечить устройству заявленный ток, оно не конфигурируется и, следовательно, не может быть использовано.

Устройство USB должно поддерживать приостановку (Suspended Mode), в котором его потребляемый ток не пре-

вышает 500 мкА. Устройство должно автоматически приос-

Возможность удаленного пробуждения (Remote Wakeup) по-

танавливаться при прекращении активности шины.

Передача данных возможна посредством одного из четырех типов передач (см. выше). Для конечных точек, допускаюших разные типы передач, после конфигурирования досту-

Управление энергопотреблением является весьма развитой функцией USB. Для устройств, питающихся от шины, мощность ограничена. Любое устройство при подключении не должно потреблять от шины ток, превышающий 100 мА.

пен только один из них.

зволяет приостановленному устройству подать сигнал хосткомпьютеру, который тоже может находиться в приостановленном состоянии. Возможность удаленного пробуждения описывается в конфигурации устройства. При конфигурировании эта функция может быть запрещена.

Хаб в USB выполняет коммутацию сигналов и выдачу питающего напряжения, а также отслеживает состояние под-

ключенных к нему устройств, уведомляя хост об изменениях. Хаб состоит из двух частей — контроллера (Hub Controller) и повторителя (Hub Repeater). Повторитель представляет собой управляемый ключ, соединяющий выходной порт со входным. Он имеет средства поддержки сброса и приостановки передачи сигналов. Контроллер содержит регистры для взаимодействия с хостом. Доступ к регистрам осуществляется по специфическим командам обращения к хабу. Команды позволяют конфигурировать хаб, управлять нисходящи-

ми портами и наблюдать их состояние. *Нисходящие (Downstream) порты* хабов могут находиться в следующих состояниях:

 Powered off (питание отключено) — на порт не подается питание (возможно только для хабов, коммутирующих в одном направлении, но способен обнаружить подключение устройства (по отсутствию состояния *SEO* в течение 2,5 мкс). Тогда порт переходит в состояние *Disabled*, а по уровням входных сигналов (*DiffO* или *Diff1* в состоянии

*Idle*) он определяет скорость подключенного устройства.

питание). Выходные буферы переводятся в высокоимпедансное состояние, входные сигналы игнорируются. Disconnected (отсоединен) — порт не передает сигналы ни

- Disabled (запрещен) порт передает только сигнал сброса (по команде от контроллера), сигналы от порта (кроме обнаружения отключения) не воспринимаются. По обнаружении отключения (2,5 мкс состояния SEO) порт переходит в состояние Disconnect, а если отключение обнаружено «спящим» хабом, контроллеру будет послан сигнал Resume.
- Enabled (разрешен) порт передает сигналы в обоих направлениях. По команде контроллера или по обнаружении ошибки кадра порт переходит в состояние Disabled, а по обнаружении отключения в состояние Disconnect.
   Suspended (приостановлен) порт передает сигнал перевода в состояние останова («спящий» режим). Если хаб находится в активном состоянии, сигналы через порт не

пропускаются ни в одном направлении. Однако «спящий»

хаб воспринимает сигналы смены состояния незапрещенных портов, подавая «пробуждающие» сигналы от активизировавшегося устройства даже через цепочку «спящих» хабов.

Состояние каждого порта идентифицируется контроллером хаба с помощью отдельных регистров. Имеется общий регистр, биты которого отражают факт изменения состояния

каждого порта (фиксируемый во время *EOF*). Это позволяет хост-контроллеру быстро узнать состояние хаба, а в случае обнаружения изменений специальными транзакциями уточнить состояние.

#### 7.1.4. Хост-контроллер

Хост-компьютер общается с устройствами через контроллер. Хост имеет следующие обязанности: манипулирование потоком управления между устройствами и хостом;
 управление потоками данных;

обнаружение подключения и отсоединения устройств

- обеспечение энергосбережения подключенными ПУ.
   Системное ПО контроллера управляет взаимодействием меж-

По возможности ПО USB использует существующее систем-

- изохронных передач данных;
- асинхронных передач данных;

USB:

шинами:

сбор статистики:

- управления энергопотреблением:
- у продили об управлении устройствами и шиной.
- ное ПО хост-компьютера например, Advanced Power Management для управления энергопотреблением.

#### 7.2. Шина IEEE 1394 — FireWire

шины (High Performance Serial Bus), получивший официальное название IEEE 1394, был принят в 1995 году. Целью являлось создание шины, не уступающей современным стандартным параллельным шинам, при существенном удешевлении и повышении удобства подключения (за счет перехода на последовательный интерфейс). Стандарт основан на

Стандарт для высокопроизводительной последовательной

да на последовательный интерфейс). Стандарт основан на шине *Fire Wire*, используемой Apple Computer в качестве дешевой альтернативы SCSI в компьютерах Macintosh и PowerMac. Название FireWire («огненный провод») теперь применяется и к реализациям IEEE 1394, оно сосуществует

PowerMac. Название FireWire («огненный провод») теперь применяется и к реализациям IEEE 1394, оно сосуществует с кратким обозначением 1394.

Преимущества FireWire перед другими последовательными

VESA позиционируется и для «домашних сетей».

Высокая скорость обмена и изохронные передачи позволяют даже на начальном уровне (100 Мбит/с) передавать одновременно два канала видео (30 кадров в секунду) широковещательного качества и стереоаудиосигнал с качеством CD.

В Низкая цена компонентов и кабеля.

№ Легкость установки и использования. FireWire расши-

Многофункциональность: шина обеспечивает цифровую связь до 63 устройств без применения дополнительной анпаратуры (хабов). Устройства — цифровые камкодеры, сканеры, принтеры, камеры для видеоконференций, дисковые накопители — могут обмениваться данными не только с РС, но и между собой. FireWire по инициативе

ряет систему PnP. Устройства автоматически распознаются и конфигурируются при включении/отключении. Питание от шины (ток до 1,5 A) позволяет ПУ общаться с системой даже при отключении их питания. Управлять шиной и другими устройствами могут не только PC, но и другие «интеллектуальные» устройства, например VCR.

#### 7.2.1. Структура и взаимодействие устройств шины

Стандарт 1394 определяет две категории шин: кабельные шины и кросс-шины (*Backplane*). Под *кросс-шинами* обычно подразумеваются параллельные интерфейсы, объединяющие внутренние подсистемы устройства, подключенного к

внутренние подсистемы устройства, подключенного к кабелю 1394.
В отличие от USB, управляемой одним хост-контроллером, стандарт 1394 допускает соединение равноправных устройств

в сеть. Сеть может состоять из множества шин, соединенных мостами. В пределах одной шины устройства объединяются соединительными кабелями без применения дополнительных устройств. *Мосты* представляют собой специальные интеллектуальные устройства. Интерфейсная карта шины FireWire для PC представляет собой мост PCI — 1394. Мостами являются также соединения кабельной шины 1394 с кроссшинами устройств. 16-битная адресация узлов сети допус-

полем идентификатора узла. 10-битное поле идентификатора шины допускает использование в системе до 1023 мостов, соединяющих шины разного типа. Кабельная шина представляет собой сеть, состоящую из уз-

кает до 63 устройств в каждой шине, адресуемых 6-битным

лов и кабельных мостов. Гибкая топология позволяет строить сети, сочетающие древовидную и цепочечную архитектуры (рис. 7.9). Каждый узел обычно имеет три равноправных соединительных разъема. Допускается множество вариантов подключения устройств со следующими ограничениями:

- между любой парой узлов может быть не более 16 кабельных сегментов;
- длина сегмента стандартного кабеля не должна превышать 4,5 м;
- суммарная длина кабеля не должна превышать 72 м (применение более качественного кабеля позволяет ослабить это ограничение).

Некоторые устройства могут иметь только один разъем, что ограничивает возможные варианты их местоположения. Стандарт допускает до 27 разъемов на одном устройстве.



**Рис. 7.9.** Соединение устройств на шине FireWire



**Рис. 7.10.** Разъем FireWire

Стандарт предусматривает связь узлов с помощью 6-провод-

ного кабеля, заключенного в общий экран. Две витые пары используются для передачи сигналов (раздельные для приемника и передатчика), два провода задействованы для питания устройств (8–40 В, до 1,5 А). Для гальванической развязки интерфейса используются трансформаторы (напряжение изоляции развязки до 500 В) или конденсаторы (в дешевых устройствах с напряжением развязки до 60 В относительно общего провода). Представление о разъемах дает рис. 7.10. Некоторые устройства (камкодеры Sony DCR-VX700 и DCR-VX1000, а также DHR-1000 DVCR) имеют только один 4-контактный разъем меньшего размера, у которого реализованы только сигнальные цепи. Эти устройства подключаются к шине через специальный переходной кабель только как оконечные (хотя возможно применение

Стандарт 1394 определяет три возможные частоты передачи сигналов по кабелям: 98,304, 196,608 и 393,216 Мбит/с, которые округляют до 100, 200 и 400 Мбит/с. Частоты в стандарте обозначаются как S100, S200 и S400 соответственно. Бытовые устройства обычно поддерживают S100, большинство адаптеров допускают S200. К одной шине могут подключаться устройства, рассчитанные на разные скорости. Обмен будет происходить на минимальной для всех активных узлов скорости. Однако, если хост-контроллер реализует карту топологии и скоростей (Topology\_Map и Speed\_Map), возможно использование нескольких частот в одной шине, в соответствии с возможностями конкретной пары, участвующей в обмене.

специальных адаптеров-разветвителей).

Система допускает динамическое (горячее) подключение и отключение устройств. Идентификаторы подключаемым

ройств) автоматически отслеживаются шиной и передаются управляющему ПО.

Протокол IEEE 1394

устройствам назначаются автоматически, без участия пользователя. Изменения топологии (состава подключенных уст-

# Протокол 1394 реализуется на трех уровнях (рис. 7.11). \*\* Уровень транзакций (Transaction Layer) преобразует па-

- кеты в данные, предоставляемые приложениям, и наобо
  - рот. Он реализует протокол запросов-ответов, соответствующий стандарту ISO/IEC 13213:1994 (ANSI/IEEE 1212, редакции 1994 г.), архитектуры регистров управления и
- состояния CSR (Control and Status Register) для микрокомпьютерных шин (чтение, запись, блокировка). Это облегчает связь шины 1394 со стандартными параллельными шинами.

  Уровень связи (Link Layer) из данных физического уров-
- уровень связи (Link Layer) из данных физического уровня формирует пакеты и выполняет обратные преобразования. Он обеспечивает обмен узлов датаграммами с подтверждениями. Уровень отвечает за передачу пакетов и управление изохронными передачами.
- управление изохронными передачами.

  Физический уровень (Physical Layer) вырабатывает и принимает сигналы шины. Он обеспечивает инициализацию и арбитраж, предполагая, что в любой момент времени
- работает только один передатчик. Уровень передает потоки данных и уровни сигналов последовательной шины вышестоящему уровню. Между этими уровнями возможна гальваническая развязка, при которой микросхемы физического уровня питаются от шины. Гальваническая развязка необходима для предотвращения паразитных контуров общего провода, которые могут появиться че-
- рез провода защитного заземления блоков питания.

  Аппаратная часть FireWire обычно состоит из двух специализированных микросхем трансиверов физического

ализированных микросхем — трансиверов физического уровня *PHY Transceiver* и моста связи с шиной *LINK Chip*. Связь между ними возможна, например, по интерфейсу IBM-Apple LINK-PHY. Микросхемы уровня связи выпол-

няют все функции своего уровня и часть функций уровня

транзакций, остальная часть уровня транзакций выполняется программно.



**Рис. 7.11.** Трехуровневая структура FireWire

#### Управление шиной

Протокол 1394 имеет гибкий механизм управления связью между различными устройствами. Для этого не обязательно

присутствие на шине PC или иного контроллера шины. Управление включает три сервиса:

- Мастер циклов, посылающий широковещательные пакеты начала циклов (требуемые для изохронных обменов).
- Диспетчер изохронных ресурсов, если какой-либо узел поддерживает изохронный обмен (для цифрового видео и аудио).

сы становятся доступными для последующего использования. Принципиальным преимуществом шины является отсутствие необходимости в контроллере. Любое передающее устройство может получить полосу изохронного трафика и начинать передачу по сигналу автономного или дистанционного

По сбросу производится определение структуры шины, каждому узлу назначаются физические адреса и производится арбитраж мастера циклов, диспетчера изохронных ресурсов и контроллера шины. Через секунду после сброса все ресур-

управлять работой устройств, реализуя, например, цифровую студию нелинейного видеомонтажа. Изохронная транспортировка данных

управления — приемник «услышит» эту информацию. При наличии контроллера (РС) соответствующее ПО может

## Изохронная транспортировка шины 1394 обеспечивает гаран-

тированную пропускную способность и ограниченную задержку при высокоскоростной передаче по множеству каналов. Диспетчер изохронных ресурсов содержит BANDWIDTH\_AVAILABLE, который определяет доступность

оставшейся части полосы пропускания для узлов с изохронной передачей. По сбросу вновь появившийся узел с изохронной передачей запрашивает выделение полосы. Для цифрового видео, например, требуется полоса 30 Мбит/с

(25 Мбит/с на видеоданные и 3-4 Мбит/с на аудио, синхронизацию и заголовки пакетов). Полоса измеряется в специальных единицах распределения, число которых в 125-миллисекундном цикле составляет 6144. Единица занимает около 20 нс, что соответствует времени, требуемому для передачи

одного квадлета (Quadlet) на частоте 1600 Мбит/с. Квадлет (32-битное слово) является единицей передачи данных по шине. 25 мс цикла резервируется под асинхронный трафик, поэтому начальное значение регистра после сброса состав-

ляет 4915 единиц. В S100 устройства цифрового видео запрашивают около 1800 единиц, в S200 — около 900. Если соответствующая полоса недоступна, запрашивающее ее

устройство будет периодически повторять запрос. Диспетчер изохронных ресурсов каждому изохронному узлу назначает номер канала (0-63) из числа доступных (регистр

канала. Обмен управляющей информацией производится по асинхронному каналу.

7.2.2. Синонимы и дополнения стандарта IEEE 1394

CHANNELS\_AVAILABLE). Он является идентификатором изохронного пакета. Когда изохронный обмен становится ненужным узлу, он должен освободить свою полосу и номер

#### 7.2.2. Синонимы и дополнения стандарта песе 1394

Шина IEEE 1394 имеет множество псевдонимов:

■ IEEE 1394-1995 Standard for a High Performance Serial

Bus — полное название документа, описывающего стан-

дарт, действующий в настоящее время.

FireWire — торговая марка реализации IEEE-1394 фир

FireWire — торговая марка реализации IEEE-1394 фирмой Apple Computer, Inc.

мои Арріе Computer, Inc.

Р1394 — название предварительной версии IEEE-1394

(до принятия в лекабре 1995 г.)

(до принятия в декабре 1995 г.).

DigitalLink — торговая марка Sony Corporation, исполь-

зуемая применительно к реализации IEEE-1394 в цифровых камерах.

MultiMedia Connection — имя, используемое в логоти-

пе 1394 High Performance Serial Bus Trade Association (1394TA).

Поскольку фирма Apple разрабатывала концепцию FireWire

Поскольку фирма Apple разрабатывала концепцию FireWire еще с 1986 года, имя FireWire является самым распространенным синонимом IEEE 1394.

ненным синонимом IEEE 1394. Кроме основного стандарта IEEE1394-1995, имеется несколько его модификаций:

1394а рассматривается как чистовой документ, заполняющий некоторые пробелы исходного стандарта и имеющий небольшие изменения (например, ускоренную операцию сброса на шине). Продуктам 1394а обеспечена

щий небольшие изменения (например, ускоренную операцию сброса на шине). Продуктам 1394а обеспечена обратная совместимость с устройствами, выпущенными до принятия основного стандарта. Версия вводилась для повышения скорости до 800 Мбит/с и выше, высокоско-

ростные версии входят и в 1394b.

1394.1 определяет 4-проводный соединитель и устанавливает стандарт на шинные мосты.

ный интерфейс 1394.2 похож на FCAL и допускает кольцевую топологию, запрещаемую стандартом 1394.

7.2.3. Сравнение FireWire и USB

Последовательные интерфейсы FireWire и USB, имея общие черты, являются существенно различными технологиями. Обе шины обеспечивают простое подключение большого числа ПУ (127 для USB и 63 для FireWire), допуская ком-

мутации и включение/выключение устройств при работающей системе. Топология обеих шин достаточно близка. Хабы USB входят в состав ЦУ; для пользователя их присутствие

1394.2 предполагается как стандарт на соединение кластера станций со скоростью обмена 1 Гбит/с и выше, несовместимый с 1394. Этот стандарт проистекает из IEEE 1596 SCI (Scalable Coherent Interface — масштабируемый когерентный интерфейс) для суперкомпьютеров и иногда называется Serial Express или SCILite. Сигналь-

незаметно. Обе шины имеют линии питания устройств, но допустимая мощность для FireWire значительно выше. Обе шины поддерживают систему PnP (автоматическое конфигурирование при включении/выключении) и снимают проблему дефицита адресов, каналов DMA и прерываний. Различаются пропускная способность и управление шиной. USB ориентирована на ПУ, подключаемые к PC. Ее изохронные передачи позволяют передавать только цифровые аудиосигналы. Все передачи управляются централизованно,

и РС является необходимым управляющим узлом, находящимся в корне древовидной структуры шины. Соединение нескольких РС этой шиной не предусматривается.

Fire Wire ориентирована на интенсивный обмен между любыми подключенными к ней устройствами. Изохронный трафик позволяет передавать «живое» видео. Шина не требует централизованного управления со стороны РС. Возможно использование шины для объединения нескольких РС и ПУ

в локальную сеть.

Новые устройства цифрового видео и аудио имеют встроенные адаптеры 1394. Подключение к шине FireWire традиционных аналоговых и цифровых устройств (плейеров, камер,

7.3. Шина ACCESS.Bus и интерфейс I<sup>2</sup>C

Последовательная шина *ACCESS.Bus* (Accessory Bus), разработанная фирмой DEC, является шиной взаимодействия компьютера с его аксессуарами — например, монитором (канал VESA DDC), интеллектуальными источниками питания (Smart Battery) и т. п. Шина позволяет по двум сигнальным и двум питающим (12 В, 500 мА) проводам подключить до 14 устройств ввода/вывода, длина шины может до-

стигать 8 м. Аппаратной основой является интерфейс I<sup>2</sup>C, характеризуемый простотой реализации, но, даже по сравнению с USB, низкой производительностью. Над аппаратным протоколом I<sup>2</sup>C для шины ACCESS. Виз имеется базовый программный протокол, с которым взаимодействуют протоколы конкретных подключенных устройств. Протоколы обеспечивают подключение/отключение устройств без перезагрузки ОС. Назначение сигналов разъема ACCESS. Виз,

ровать трафик групп узлов друг от друга.

мониторов) возможно через адаптеры-преобразователи интерфейсов и сигналов. Стандартные однотипные кабели и разъемы FireWire заменяют множество разнородных соединений устройств бытовой электроники с РС. Разнотипные цифровые сигналы мультиплексируются в одну шину. В отличие от сетей Ethernet, высокоскоростные передачи потоков данных по FireWire в реальном времени не требуют дополнительных протоколов. Кроме того, имеются средства арбитража, гарантирующие доступ к шине за заданное время. Применение мостов в сетях FireWire позволяет изоли-

предложенное VESA, приведено в табл. 7.3.

Таблица 7.3. Разъем ACCESS.Bus (VESA)

 Контакт
 Назначение

 1
 GND

 2
 Ключ

 3
 SDA

 4
 +5 В (питание устройств)

 5
 SCL

Интерфейс I<sup>2</sup>C, разработанный фирмой Philips, в PC появился недавно и используется как внутренняя вспомогательная шина системной платы для общения с энергонезависимой памятью идентификации установленных компонентов (модулей памяти DIMM). Шина отличается предельной простотой реализации — две сигнальные линии, с которыми работают программно. По прямому назначению эту шину

применяет пока только BIOS при определении аппаратных средств, но использование перезаписываемой памяти конфигурирования открывает новые возможности для привязки ПО к конкретной системе (точнее, установленному модулю) и... для вирусов. Способ программного доступа к шине пока не стандартизован, но при желании его можно «вычислить», изучив документацию на чипсет.



Рис. 7.12. Протокол передачи данных I<sup>2</sup>C
Последовательный интерфейс I<sup>2</sup>C обеспечивает двунаправ-

ленную передачу данных между парой устройств, исполь-

зуя два сигнала: данные SDA (Serial Data) и синхронизацию SCL (Serial Clock). В обмене участвуют два устройства — ведущее (Master) и ведомое (Slave). Каждое из них может выступать в роли передатика, помещающего на линию SDA информационные биты, или приемника. Протокол обмена иллюстрирует рис. 7.12. Синхронизацию задает ведущее устройство — контроллер. Линия данных — двунаправленная с выходом типа «открытый коллектор» — управляется обоими устройствами поочередно. Частота обмена (не обязательно постоянная) ограничена сверху величиной 100 кГц для стандартного режима и 400 кГц для скоростного, что позволяет организовать программно-управляемую реализацию контрол-

Начало любой операции — условие *Start* — инициируется переводом сигнала SDA из высокого в низкий при высоком уровне SCL. Завершается операция переводом сигнала SDA

лера интерфейса.

передатчик на один такт освобождает линию данных для получения подтверждения. Приемник во время девятого такта формирует нулевой бит подтверждения Аск. После передачи бита подтверждения приемник может задержать следующую посылку, удерживая линию SCL на низком уровне. Приемник также может замедлить передачу по шине на уровне приема каждого бита, удерживая SCL на низком уровне после его спада, сформированного передатчиком. Каждое ведомое устройство имеет свой адрес, разрядность которого по умолчанию составляет 7 бит. Адрес А[6:0] передается ведущим устройством в битах [7:1] первого байта, бит 0 содержит признак операции RW (RW=1 — чтение, RW=0 — запись). 7-битный адрес содержит две части: старшие 4 бита А[6:3] несут информацию о типе устройства (например, для EEPROM - 1010), а младшие 3 бита A[0:2] определяют номер устройства данного типа. Многие микросхемы с интерфейсом I2C имеют три адресных входа, коммутацией которых на логические уровни 1 и 0 задается требуемый адрес. Некоторые значения полного адреса зарезервированы (табл. 7.4). Общий вызов позволяет включившемуся устройству заявить о себе широковещательным способом. Байт Start предназначен для привлечения внимания процессора к интерфейсу, если в устройстве он организован программным (не аппаратным) способом. До получения этого байта микроконтроллер устройства не опрашивает состояние и не следит за сигналами интерфейса. При использовании 10-битной адресации биты [2:1] содержат старшую часть адреса, а младшие 8 бит будут переданы в следующем байте, если признак *RW*=0. Адрес ведомого устройства и тип обращения задается кон-

троллером при инициировании обмена. Обмен с памятью иллюстрирует рис. 7.13. Здесь SA[0:2] — адрес устройства, DA[0:7] — адрес данных, D[0:7] — данные, W — признак за-

писи (0), R — признак чтения (1).

из низкого уровня в высокий при высоком уровне SCL — условие *Stop*. При передаче данных состояние линии SDA может изменяться только при низком уровне SCL, биты данных стробируются положительным перепадом SCL. Каждая посылка состоит из 8 бит данных, формируемых передатчиком (старший бит — MSB — передается первым), после чего

#### яблица: 7.4. Специальные адреса РС

| Биты [7:1] | Бит О (RW) | Назначение                                          |
|------------|------------|-----------------------------------------------------|
| 0000 0000  | 0          | General call address — адрес общего вызова          |
| 0000 0000  | 1          | Start — начало активного обмена                     |
| 0000 001   | Х          | Адрес устройства шины CBUS (для сов-<br>местимости) |
| 0000 010   | Х          | Адрес для устройств иных шин                        |
| 0000 011   | Х          | Зарезервировано                                     |
| 0000 1XX   | Х          | Зарезервировано                                     |
| 1111 1XX   | Х          | Зарезервировано                                     |
| 1111 OXX   | Х          | Признак 10-битной адресации                         |



**Рис. 7.13.** Обмен с памятью по интерфейсу  $I^2C$ : a — запись,  $\delta$  — чтение с текущего адреса, B — чтение с произвольного адреса

Выполнив условие *Start*, контроллер передает байт, содержащий адрес устройства и признак операции *RW*, и ожидает подтверждения. При операции записи следующей посылкой от контроллера будет 8-битный адрес записываемой ячейки, а за ней — байт данных (для микросхем объемом памяти бо-

лее 256 байт адрес ячейки посылается двумя байтами). Получив подтверждения, контроллер завершает цикл условием *Stop*, а адресованное устройство может начать свой внутренний цикл записи, во время которого не реагирует на сигналы интерфейса. Контроллер проверяет готовность устройства посылкой команды записи (байт адреса устройства)

Stop. Если устройство откликнулось битом подтверждения, значит, оно завершило внутренний цикл и готово к следующей операции.

Операция считывания инициируется так же, как и запись, но с признаком RW=1. Возможно чтение по заданному адресу, по текущему адресу или последовательное. Текущий адрес хранится во внутреннем счетчике ведомого устройства, он содержит увеличенный на единицу адрес ячейки, участвовавшей в последней операции.

Получив команду чтения, устройство дает бит подтверждения и посылает байт данных, соответствующий текущему

и анализом бита подтверждения, формируя затем условие

устройство пошлет следующий байт (последовательное чтение). Если на принятый байт данных контроллер ответит условием *Stop*, операция чтения завершается (случай чтения по текущему адресу). Начальный адрес для считывания контроллер задает фиктивной операцией записи, в которой передается байт адреса устройства и байт адреса ячейки, а после подтверждения приема байта адреса снова формируется условие *Start* и передается адрес устройства, но уже с указанием на операцию чтения. Так реализуется считывание произвольной ячейки (или последовательности ячеек). Интерфейс позволяет контроллеру с помощью пары сигна-

адресу. Контроллер может ответить подтверждением, тогда

лов обращаться к любому из 8 однотипных устройств, подключенных к данной шине и имеющих уникальный адрес (рис. 7.14). При необходимости увеличения количества устройств возможно подключение групп. При этом допустимо как использование общего сигнала SCL и раздельных сигналов SDA (двунаправленных), так и общего сигнала SDA и раздельных однонаправленных сигналов SCL. Для обращения к одной из нескольких микросхем (или устройств), не

ния к однои из нескольких микросхем (или устроиств), не имеющих выводов для задания собственного адреса, также применяют разделение линий SCL (или SDA).

Протокол I<sup>2</sup>C позволяет нескольким контроллерам использовать одну шину, определяя коллизии и выполняя арбит-

раж. Эти функции реализуются достаточно просто: если два передатчика пытаются установить на линии SDA различные

управляемых им сигналов и при обнаружении несоответствия (передает высокий уровень, а «видит» низкий) отказывается от дальнейшей передачи. Устройство может инициировать обмен только при пассивном состоянии сигналов. Коллизия может возникнуть лишь при одновременной попытке начала обмена — как только конфликт обнаружен, «проигравший» передатчик отключится, а «победивший» продолжит работи.

логические уровни сигналов, то «победит» тот, который установит низкий уровень. Передатчик следит за уровнями



Рис.7.14. Подключение устройств к контроллеру I<sup>2</sup>C

# Приложение А. Системотехника IBM РС-совместимых компьютеров

туре РС. Описаны организация пространств памяти и ввода/вывода, система прерываний и прямой доступ к памяти. Более подробные сведения можно найти в книге «Аппаратные средства IBM РС. Энциклопедия» («Питер», 1998).

Здесь рассмотрено взаимодействие программ с интерфейсными адаптерами. Приведены краткие сведения по архитек-

### А.1. Пространство памяти

ресации процессоров семейства x86. Процессоры 8086/88, применявшиеся в первых моделях IBM PC, имели адресное пространство 1 Мбайт (20 бит шины адреса). Начиная с процессора 80286 шина адреса была расширена до 24 бит, затем

(386DX, 486, Pentium) до 32 и, наконец, до 36 бит (Pentium Pro, Pentium II). В реальном режиме процессора,

Логическая структура памяти РС обусловлена системой ад-

используемом в DOS, формально доступен лишь 1 Мбайт памяти. Однако из-за ошибки эмуляции процессора 8086 в реальном режиме процессоры 80286 и выше имеют максимально доступный адрес 10FFEFh, что на (64K-16) байт больше. Область 100000h-10FFEFh называется высокой па-

ОС реального режима и небольшие резидентные программы. Для полной совместимости с процессором 8086/88 имеется вентиль линии A20 шины адреса — *GateA20*, который либо пропускает сигнал от процессора, либо принудительно обнуляет линию A20 системной шины адреса.

мятью — High Memory Area (HMA). В нее помещают часть

стом POST при включении компьютера, начиная с младших адресов. Натолкнувшись на отсутствие памяти (ошибку), тест останавливается и сообщает системе объем памяти. Память, непосредственно адресуемая процессором, распре-

Основную часть адресного пространства занимает оперативная память. Объем установленной памяти определяется те-

деляется следующим образом: 00000h-9FFFFh - Conventional (Base) Memory, 640 Кбайт — стандартная (базовая) память, доступная

DOS и программам реального режима. В некоторых системах с видеоадаптером MDA верхняя граница сдвигается к AFFFFh (704 Кбайт). Иногда верхние 128 Кбайт стандартной памяти (область 80000h-9FFFFh) называют Extended Conventional Memory. A0000h-FFFFFh - Upper Memory Area (UMA), 384 Кбайт — верхняя память, зарезервированная для си-

стемных нужд. В ней размещаются буферы интерфейсных адаптеров (например, видеопамять) и постоянная память (BIOS с расширениями). Память выше 100000h — Extended Memory — дополнительная (расширенная) память, непосредственно доступная только в защищенном режиме компьютеров 286 и выше-

Для компьютеров класса АТ с 24-битной шиной адреса верхняя граница дополнительной памяти — FDFFFFh (максимальный размер 14,9 Мбайт). Область FE0000h-FFFFFFh содержит ПЗУ BIOS (ROM BIOS Area); обращение к ней эквивалентно обращению к ROM BIOS по адресам 0E0000h-

OFFFFFh. Для процессоров 386 и 32-битной шины адреса теоретическая верхняя граница — 4 Гбайт, а для Pentium Pro и Pentium II — 64 Гбайт (36-битная шина адреса). Обращение по адресам, превышающим границу установленной опера-

тивной памяти (или максимально возможного объема), транслируется на шину РСІ, которая имеет 32-битную ад-

ресацию. В компьютерах с 32-разрядной шиной адреса образ BIOS дополнительно проецируется в адреса FFFE0000h-

FFFFFFFh. Иногда используется проекция BIOS в область FE0000h-FFFFFh, что не позволяет использовать более

Для взаимодействия с интерфейсными адаптерами ISA интересна верхняя память UMA. Стандартное распределение верхней памяти выглядит следующим образом: A0000h-BFFFFh — Video RAM. 128 Кбайт — видеопамять (обычно используется не полностью). C0000h-DFFFFh - Adapter ROM, Adapter RAM, 128 Кбайт — зарезервировано для адаптеров, использующих собственные модули ROM BIOS и/или специальное ОЗУ, разделяемое с системной шиной. E0000h-EFFFFh — свободная область. 64 Кбайт, иногда занятая под System BIOS. F0000h-FFFFFh - System BIOS, 64 Кбайт - ROM на системной плате (в XT используется только FE000h-FFFFFh - 8 K6amm). FD000h-FDFFFh - ESCD (Extended System Configuration Data) — область энергонезависимой памяти, используемая для конфигурирования устройств PnP. Эта область присутствует только при наличии PnP BIOS; ее положение и размер жестко не заданы. В области UMA практически всегда присутствует графичес-

16 Мбайт ОЗУ, поскольку система находит только непрерывную область расширенной памяти. Для использования специфических адаптеров ISA, имеющих буфер с адресами в 16-м мегабайте памяти, в BIOS Setup предусматривают опцию *Memory Hole At* 15–16M. Ее установка не позволяет

использовать оперативную память свыше 16 Мбайт.

VGA ROM — C0000h—C7FFFh

EGA, VGA RAM — A0000h—BFFFFh, в зависимости от видеорежима используются следующие области: Graphics —
A0000h—AFFFFh; Color Text — B8000h—BFFFFh; Mono

кий адаптер. В зависимости от модели он занимает следую-

шие области:

MDA RAM — B0000h-B0FFFh CGA RAM — B8000h-BBFFFh

Text - B0000h-B7FFFh.

EGA ROM - C0000h-C3FFFh/C7FFFh

леров, адаптеров SCSI, сетевых картах и т. д. Обычно они занимают область C8000h — CBFFFh/C9FFFh/C8FFFh (для дисковых контроллеров), но могут перемещаться при конфигурировании адаптеров.

Процессоры x86 имеют раздельную адресацию памяти и портов ввода/вывода. Инструкции ввода/вывода порождают шинные циклы обмена, в которых вырабатываются сигналы IORD# (чтение порта) и IOWR# (запись в порт) на шинах ввода/вывода. Эти сигналы отличают пространство ввода/вывода от пространства памяти, где соответствующие операции чтения и записи вырабатывают сигналы MEMRD# и MEMWR#. Для обращения к пространству ввода/вывода пред-

Распространенным потребителем UMA являются *расширения ROM BIOS*, расположенные на платах дисковых контрол-

## А.2. Пространство ввода/вывода

назначены четыре основные инструкции процессора: *IN* (ввод в регистр), *OUT* (вывод из регистра), *INS* (ввод из порта в элемент строки памяти) и *OUTS* (вывод элемента из строки памяти). Последние две инструкции с префиксом повтора *REP* используются для быстрой пересылки блоков данных между портом и памятью. Разрядность слова, передаваемого за одну инструкцию ввода/вывода, может составлять 8, 16 или 32 бита. В зависимости от выравнивания адреса по границе слова и разрядности шины это слово может передаваться за один или несколько циклов шины.

в этом случае на шину адреса подается адрес памяти, к которой производится доступ, а не порта. Для блокировки срабатывания дешифратора адреса порта в цикле DMA в шине ISA имеется сигнал AEN. Селективное программное управление сигналом AENх для каждого слота шины EISA дает возможность изолировать пространства ввода/вывода портов, что используется для программного конфигурирования адресов адаптеров. В шине ISA разделение слотов не предусмотрено, что объясняет сложность реализации для нее системы PnP.

Для дешифрации адреса в оригинальном РС из 16 бит использовались только младшие 10 (АО-А9), что позволяет об-

Сигналы IORD# и IOWR# вырабатываются и в циклах DMA;

устройствами одинаково. В адаптерах для шин МСА и РСІ используются все 16 бит адреса. Современные системные платы полностью дешифруют адрес. В реальном режиме процессора программе доступно все пространство адресов ввода/вывода. В защищенном режиме (в частности, в режиме виртуального процессора 86) можно программно ограничить пространство ввода/вывода, определив его максимальный размер. Внутри разрешенной области доступ может быть разрешен или запрещен для каждого конкретного адреса. Размер области и карта разрешенных портов (IO Permission Bitmap) задаются ОС в дескрипторе сегмента состояния задачи (TSS). При обращении по неразрешенному адресу вырабатывается исключение процессора, обработчик которого определяется ОС. Возможно снятие задачи-нарушителя. Не исключено, что по обращению к порту ОС выполнит некоторые действия, создав для программы иллюзию реальной операции ввода/вывода. Несколько портов вывода могут иметь совпадающие адреса. Операции записи они будут отрабатывать нормально. Для операций считывания ситуация другая. Если несколько портов ввода имеют совпадающий адрес, при считывании они передают свои данные на шину. Если они находятся на одной физической шине, возникает конфликт. При прочих равных условиях для каждого бита шины «побеждает» порт, выводящий логический ноль. Так, если один порт «хочет» передать байт 0Fh, а другой — F0h, то процессор считает 00h. Если порты находятся на разных физических шинах (например, один в ISA, а другой — в PCI), конфликта не будет, поскольку шины отделены друг от друга буферами данных. Каждой шине назначается своя область ввода, и дешифра-

ращаться к портам 0-3FFh. Старшие биты адреса, хотя и поступают на шину, устройствами игнорируются. Так, обращение по адресам 378h, 778h, B78h и F78h воспринимается

(и сигнал записи) обычно распространяются по всем шинам компьютера. Адреса 0h-0FFh отведены для устройств системной платы, чтение по этим адресам не распространя-

тор, расположенный на системной плате, при чтении открывает соответствующие буферы, так что реально считываются данные только с одной шины. При записи в порты данные

ется на шины расширения. Для современных плат со встроенной периферией и несколькими шинами (ISA, PCI) распределением адресов управляет BIOS через регистры конфигурирования чипсета. Приведенные выше рассуждения справедливы и для пространства памяти, но, как правило, они актуальны только для портов ввода/вывода. Карта распределения адресов ввода/вывода стандартных устройств приведена в табл. А.1. Подразумевается 10-битная дешифрация адреса. биць А.Г. Станцитан парта поутов возвальное AT u PS/2 PC/XT Назначение 000-00F 000-00F Конгроддер DMA #1 8237 010-01F PS/2 — расширение DMA #1 020-021 020-021 Контроллер прерываний #1 - 8259А 040-05F 040-043 Таймер (РС/ХТ: 8253, АТ: 8254) 060 060 Диагностический регистр POST (только запись) 060-063 Системный интерфейс 8255 060.064 Конгроллер клавиатуры АТ 8042 061 Источники NMI и управление звуком 070-07F Память CMOS и маска NMI 080 Диагностический регистр 080-08F 080-083 Регистры страниц DMA 090-097 PS/2: микроканал, арбитр и т. д. Маска NMI 0A0 0A0-0BF Контроллер прерываний #2 — 8259А 0C0-0DF Контроллер DMA #2 8237A-5 0F0-0FF Сопроцессор 80287 100-1EF Управление микроканалом PS/2 170-177 Контроллер НЖМД #2 (IDE#2) 1F0-1F7 Конгроллер НЖМД #1 (IDE#1)

# Таблица А.1 (продолжение)

| AT u PS/2        | PC/XT   | Назначение                                       |  |
|------------------|---------|--------------------------------------------------|--|
| 200-207          | 200-20F | Игровой адаптер                                  |  |
|                  | 210-217 | Блок расширений                                  |  |
| 23 <b>8-23</b> F |         | COM4                                             |  |
| 278-27F          | 278-27F | Параллельный порт LPT2<br>(LPT3 при наличии MDA) |  |
|                  | 2A2-2A3 | Часы MSM48321RS                                  |  |
| 2C0-2DF          | 2C0-2DF | EGA #2                                           |  |
| 2E0-2E7          |         | COM4                                             |  |
| 2E8-2EF          |         | COM4                                             |  |
| 2F8-2FF          | 2F8-2FF | COM2                                             |  |
| 300-31F          |         | Плата-прототип                                   |  |
|                  | 320-32F | Жесткий диск XT                                  |  |
| 338-33F          |         | СОМЗ                                             |  |
| 370-377          |         | Конгроллер НГМД #2                               |  |
| 376-377          |         | Порты команд IDE#2                               |  |
| 378-37F          | 378-37F | Параллельный порт LPT1<br>(LPT2 при наличии MDA) |  |
| 380-38F          | 380-38F | Синхронный адаптер SDLC/BSC #2                   |  |
| 3A0-3AF          | 3A0-3A9 | Синхронный адаптер BSC #1                        |  |
| 3B0-3BB          | 3B0-3BB | Монохромный адаптер (МDA)                        |  |
| 3B4-3C9          |         | Видеосистема PS/2                                |  |
| 3BC-3BF          | 3BC-3BF | Параллельный порт LPT1 платы MDA                 |  |
| 3C0-3CF          | 3C0-3CF | EGA #1                                           |  |
| 3C0-3DF          | 3C0-3DF | VGA                                              |  |
| 3D0-3DF          | 3D0-3DF | CGA/EGA                                          |  |
| 3E0-3E7          |         | COM3                                             |  |
| 3E8-3EF          |         | СОМ3                                             |  |
| 3F0-3F7          | 3F0-3F7 | Конгроллер НГМД #1                               |  |
| 3F6-3F7          |         | Порты команд IDE#1                               |  |
| 3F8-3FF          | 3F8-3FF | COM1                                             |  |

## А.З. Аппаратные прерывания

NMI позволяют биты 6, 7 регистра 061h.

на события, происходящие асинхронно по отношению к исполняемому программному коду. Процессоры х86 поддерживают таблицу, содержащую определения до 256 процедур обслуживания прерываний. Немаскируемые прерывания NMI

Аппаратные прерывания обеспечивают реакцию процессора

обслуживания прерываний. *Немаскируемые прерывания* NMI обрабатываются процессором независимо от состояния флага разрешения прерывания *IF*. К ним относятся прерывания, приходящие по линии NMI, а для процессоров, поддержива-

ющих режим системного управления, еще и по линии SMI#. Сигнал на линию NMI приходит от схем контроля паритета памяти, от линии IOCHK шины ISA или SERR# шины PCI. В машинах класса AT сигнал NMI блокируется до входа про-

цессора установкой бита 7 порта 070h в 1, отдельные источники— битами 2, 3 порта 061h. Идентифицировать источник

В XT NMI вызывается и математическим сопроцессором при возникновении исключения. Запретить NMI позволяет обнуление бита 7 порта 0A0h; отдельные источники блокируются битами 4, 5 регистра 061h; биты 6, 7 регистра 062h идентифицируют источник.

Обработка маскируемых прерываний может запрещаться ин-

струкцией DI и разрешаться — EI (или другим способом воз-

действия на флаг процессора *IF*). Эти прерывания обслуживаются контроллером, программно-совместимым с 8259А. Он имеет 8 входов запросов прерываний IRQх от внешних источников. При обработке запроса контроллер передает по шине данных 8-битный *вектор прерывания*, соответствующий номеру запроса. Этот вектор является индексом, по которому ссылка на процедуру обработки прерывания хранится в

таблице прерываний.

В машинах класса АТ используются два контроллера прерываний. Ведущий (первичный) контроллер 8259А#1 обслуживает запросы 0, 1, 3–7. К его входу 2 подключен ведомый (вторичный) контроллер 8259А#2, который обслуживает запросы 8–15. При этом используется вложенность приоритетов — запросы 8–15 со своим рядом убывающих приорите-

| лера, приор том номера. линий запро На входы к системных значаются к А.2). Преры вания их пр линиям заприниям запр | оитеты з<br>В XT о,<br>осов.<br>онтролл<br>устройс<br>ак IRQx з<br>вания е<br>опорите<br>росов ко<br>ры могу | нежду запросами 1 и 3 ведущего контрол-<br>запросов которого также убывают с рос-<br>дин контроллер 8259А обслуживал все 8<br>неров прерываний поступают запросы от<br>ств и плат расширения. Эти линии обо-<br>и имеют общепринятое назначение (табл.<br>в табл. А.2 расположены в порядке убы-<br>тов. Номера векторов, соответствующих<br>онтроллеров, система приоритетов и дру-<br>т задаваться программно при инициали-<br>в. |
|--------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Toberato A.2./                                                                                                     | лперетны                                                                                                     | s <del>Specialities</del>                                                                                                                                                                                                                                                                                                                                                                                                           |
| Имя (номер)                                                                                                        | Вектор                                                                                                       | Назиачение                                                                                                                                                                                                                                                                                                                                                                                                                          |
| NMI                                                                                                                | 02h                                                                                                          | Контроль канала, паритет (в ХТ — сопроцессор)                                                                                                                                                                                                                                                                                                                                                                                       |
| 0                                                                                                                  | 08h                                                                                                          | Таймер (канал 0 8253/8254)                                                                                                                                                                                                                                                                                                                                                                                                          |
| 1                                                                                                                  | 09h                                                                                                          | Клавиатура                                                                                                                                                                                                                                                                                                                                                                                                                          |
| IRQ2                                                                                                               | 0Ah                                                                                                          | XT — произвольно,<br>AT — каскад IRQ8-IRQ15                                                                                                                                                                                                                                                                                                                                                                                         |
| 8                                                                                                                  | 70h                                                                                                          | CMOS RTC — часы реального времени                                                                                                                                                                                                                                                                                                                                                                                                   |
| IRQ9                                                                                                               | 71h                                                                                                          | Произвольно                                                                                                                                                                                                                                                                                                                                                                                                                         |
| IRQ10                                                                                                              | 72h                                                                                                          | Произвольно                                                                                                                                                                                                                                                                                                                                                                                                                         |
| IRQ11                                                                                                              | 73h                                                                                                          | Произвольно                                                                                                                                                                                                                                                                                                                                                                                                                         |
| IRQ12                                                                                                              | 74h                                                                                                          | PS/2-Mouse или произвольно                                                                                                                                                                                                                                                                                                                                                                                                          |
| 13                                                                                                                 | 75h                                                                                                          | Математический сопроцессор                                                                                                                                                                                                                                                                                                                                                                                                          |
| IRQ14                                                                                                              | 76h                                                                                                          | HDC — контроллер НЖМД                                                                                                                                                                                                                                                                                                                                                                                                               |
| IRQ15                                                                                                              | 77h                                                                                                          | Произвольно                                                                                                                                                                                                                                                                                                                                                                                                                         |
| IRQ3                                                                                                               | 0Bh                                                                                                          | COM2, COM4                                                                                                                                                                                                                                                                                                                                                                                                                          |
| IRQ4                                                                                                               | 0Ch                                                                                                          | COM1, COM3                                                                                                                                                                                                                                                                                                                                                                                                                          |
| IRQ5                                                                                                               | 0Dh                                                                                                          | XT — HDC,<br>AT — LPT2, Sound (произвольно)                                                                                                                                                                                                                                                                                                                                                                                         |
| IRQ6                                                                                                               | 0Eh                                                                                                          | FDC — контроллер НГМД                                                                                                                                                                                                                                                                                                                                                                                                               |
|                                                                                                                    |                                                                                                              |                                                                                                                                                                                                                                                                                                                                                                                                                                     |

0Fh

IRQ7

LPТ1 — принтер

ми. Тогда обработчик прерывания устройства, определив, что источник — не его, вызывал бы обработчик другого устройства, работающего с той же линией. Однако в шине ISA прерывание вырабатывается по положительному перепаду сигнала на линии запроса. Такой способ подачи сигнала имеет меньшую помехозащищенность, чем срабатывание по отрицательному перепаду, и отрезает путь к нормальному разделяемому использованию линий, для которого полностью пригоден способ подачи сигнала по низкому уровню. Поскольку традиционный контроллер позволяет задавать чувствительность — уровень (Level) или перепад (Edge) — только для всех входов одновременно, разделяемые прерывания на шине ISA неработоспособны. Тем не менее, некоторые чипсеты, реализующие контроллеры прерываний, допускают индивидуальное управление чувствительностью каждого входа. Тогда при соответствующих возможностях BIOS Setup и адаптеров разделяемые прерывания технически реализуемы. При чувствительности к уровню сигнал запроса аппаратно-

Назначение номеров прерываний — процесс двухсторонний: адаптер должен быть сконфигурирован на использование конкретной линии шины (джамперами или программно), а ПО, поддерживающее данный адаптер, должно быть проинформировано о номере используемого вектора. Поскольку прерывания являются дефицитным ресурсом, возникает желание разделить эти линии между несколькими устройства-

ветствующим регистрам адаптера. Для запросов прерывания с шины РСІ используются 4 линии, которые обозначают как INTR A, B, C, D. Возможно их разделяемое использование. Линии циклически сдвигаются в

го прерывания IRQх должен удерживаться генерирующей схемой по крайней мере до цикла подтверждения прерывания процессором. В противном случае источник прерывания не будет правильно идентифицирован. Обычно адаптеры строят так, что сигнал запроса сбрасывается при обращении программы обслуживания прерывания к соот-

слотах (рис. А.1) и независимо коммутируются на доступные IRQx с помощью конфигурационных регистров чипсета. Линии IRQx, используемые шиной PCI, недоступны для шины

Линии ІНОх, используемые шинои РСІ, недоступны для шины ISA. «Дележку» линий между шинами, а также управление BIOS Setup, а также система PnP. В опциях настройки *ISA* или *Legacy* подразумевают использование линий IRQx традиционными адаптерами шины ISA (статическое распределение), а *PCI/PnP* — адаптерами шины PCI или адаптерами PnP для

чувствительностью отдельных линий выполняют настройки

шины ISA (динамическое распределение). PCI#4 PCI#3 PCI#2 PCI#1 INTA INTC INTB INTA INTD INTB **PCI** INTC INTD INTA INTB INTR Chipset INTC INTD INTA INTB INTD INTB INTC INTD INTA Слоты РСІ От устройств ISA

Рис. А.1. Коммутация запросов прерывания шины РСІ

### А.4. Прямой доступ к памяти и прямое управление шиной

Прямой доступ к памяти — DMA (Direct Memory Access) — метод обмена ПУ с памятью без участия процессора. В обычном программном обмене (PIO) при пересылке блока данных, например, из порта в память (инструкция  $REP\ INSB$ ), выполняются следующие действия:

- Процессор генерирует шинный цикл чтения порта, выставляя его адрес и формируя сигнал IORD#. Данные из порта считываются процессором во внутренний шинный буфер.
- Процессор генерирует шинный цикл записи в память, выставляя адрес ячейки и формируя сигнал МЕМWR#. Данные из внутреннего шинного буфера записываются в память.
- Эти шаги автоматически повторяются с изменением адреса памяти. Количество повторов задается в регистре СХ,

редачи всего блока процессор занят. В режиме прямого доступа к памяти процессор инициализирует контроллер прямого доступа к памяти — задает на-

инкремент/декремент адреса — флагом *DF*. Во время пе-

чальный адрес, счетчик и режим обмена, после чего освобождается. Обмен производит контроллер и выполняет его несколько иначе. Контроллер имеет несколько каналов. Для интерфейса ПУ каждый канал представляется парой сигна-

лов: запрос обмена — DRQх и подтверждение обмена — DACKх#. В операциях по каналу DMA адрес порта не фигурирует, а используется только пара сигналов, соответствующая номеру канала. Цикл передачи блока в память будет выглядеть следующим образом (рис. A.2):

- По сигналу DRQх контроллер запрашивает управление шиной и дожидается его предоставления процессором (и другими контроллерами шины).
   Контроллер выставляет адрес ячейки памяти и форми-
- рует в одном цикле шины сигналы IORD#, DACKx# и MEMWR#. Сигнал DACKx# указывает на то, что операция выполняется для канала «x», а IORD# на направление в канале (для пересылки из памяти в канал использовался бы сигнал IOWR#). Чтобы по сигналу IORD# не было лож-
- ного чтения (по IOWR# ложной записи) порта, адрес которого совпадает с адресом памяти, присутствующим в цикле DMA, контроллер высоким уровнем сигнала AEN запрещает портам дешифрацию адреса. Байт, считанный из канала, в том же цикле шины записывается в ячейку памяти.
- памяти.

  3. Контроллер модифицирует счетчик адреса и повторяет шаги 1—2 для каждого следующего сигнала DRQx, пока не будет исчерпан счетчик циклов. В последнем цикле обмена контроллер формирует общий сигнал окончания TC (Тегminate Count), который может быть использован

мена контроллер формирует общий сигнал окончания IC (Terminate Count), который может быть использован устройством для формирования сигнала аппаратного прерывания.

Обратная пересылка отличается только тем, что использу-

ются сигналы IOWR# и MEMRD#.



Процессор при обмене занят только инициализацией контроллера, которая сводится к записи в его регистры нескольких байт. Затем обмен производят системная шина и контроллер. Если выбранный режим обмена не занимает всей пропускной способности шины, во время операций DMA процессор может продолжать работу.

Прямой доступ к памяти был использован еще в РС/ХТ, где применялась микросхема *четырехканального контроллера DMA* i8237A. Контроллер имеет 16-разрядные регистры адреса и счетчики, что позволяет программировать передачу блоков до 64 Кбайт. Для доступа к пространству размером в 1 Мбайт применили внешние 4-разрядные регистры страниц DMA, отдельные для каждого канала. В них хранятся биты адреса A[19:16], а битами A[15:0] управляет контроллер. При достижении регистром-счетчиком адреса значения FFFFh следующее его значение будет 0000h, а внешний регистр адреса страницы останется неизменным. Таким образом, если блок начинается не с границы страницы памяти

размером в 64 Кбайт, возможно его «сворачивание в кольцо». Но если для процессоров 80х86 в реальном режиме «сворачиваемые» сегменты могут начинаться с адреса, кратного 10h, то при прямом доступе границы «сворачиваемого» сегмента кратны 10000h. Этот эффект обязательно необходимо учи-

передачу данных и называются 8-битными каналами DMA. В архитектуре АТ подсистему DMA расширили, добавив второй контроллер 8237А. Его подключили к шине адреса со смещением на 1 бит. 16-битные регистры адреса способны управлять линиями адреса А[16:1], младший бит адреса АО всегда нулевой. Таким образом, второй контроллер передает данные только по два байта, поэтому его каналы названы 16-битными. За один сеанс второй контроллер способен передать до 64 К 16-разрядных слов. Регистры страниц для всех каналов DMA у AT расширены до 8 бит, что делает доступной для любого канала область памяти размером 16 Мбайт (0-FFFFFh). Эффект «сворачивания» сегментов в каналах прямого доступа сохраняется, только для каналов 5, 6 и 7 «кольца» имеют размер 64К слов и границы, кратные 20000h. Микросхемы контроллеров 8237А включены каскадно, и канал 4 недоступен — через него подключается первый контроллер. Стандартное назначение каналов приведено в табл. А.З. Кроме увеличения числа каналов в АТ ввели управление шиной ISA — Bus-Mastering — со стороны адаптера. Оно опирается на контроллер DMA, выполняющий в данном случае функции арбитра шины. Для получения управления шиной адаптер посылает запрос по линии DRQx (только для каналов 5-7) и, получив подтверждение DACKx, устанавливает сигнал MASTER#. Теперь шиной ISA управляет он, но не имеет права занимать шину более чем на 15 мкс за сеанс.

В противном случае нарушится регенерация памяти. Интеллектуальный контроллер может выполнять более эффектив-

Управление шиной используют высокопроизводительные адаптеры SCSI и локальных сетей, а также интеллектуаль-

ные процедуры обмена, чем стандартный DMA.

тывать при программировании прямого доступа — блок, пересекающий границу, должен пересылаться за два сеанса DMA, между которыми канал (включая регистр страниц)

Из четырех каналов DMA XT на шине ISA доступны только три (1, 2 и 3). Канал 0 используется для регенерации динамической памяти, адрес регенерируемой строки берется с линий адреса ISA. Каналы 1, 2 и 3 обеспечивают побайтную

должен быть повторно инициализирован.

Ограничения на доступную память для «чистого» режима DMA в новых компьютерах снимаются применением расширенных регистров страниц, но об этом должно «знать» ПО. На шине EISA каналы DMA могут работать в 8-, 16-и 32-битном режиме и, используя все 32 разряда шины ад-

ные графические адаптеры. Однако архитектурой шины до-

ступное им пространство ограничено 16 Мбайт.

нал программируется на 1 из 4 типов цикла передачи:

« Compatible — полностью совместим с ISA.

« Туре А — сокращенный на 25% цикл: время одиночного цикла 875 нс, в блочном режиме время цикла 750 нс. Ра-

реса, иметь доступ ко всей памяти компьютера. Каждый ка-

- ботает почти со всеми ISA-адаптерами с большей скоростью.

  Туре В сокращенный на 50% цикл (750/500 нс на цикл), работает с большинством EISA-адаптеров и некоторыми
- ISA. Возможен только с памятью, непосредственно доступной контроллеру шины EISA (то есть с памятью на адаптерах EISA и системной, если EISA является основной шиной). Если декодированный адрес памяти относится к 8/16-битной памяти ISA, то контроллер DMA
- EISA автоматически переводится в режим Compatible.

  Туре С (Burst Timing) сокращенный на 87,5% цикл, ориентированный на пакетный режим передачи. Работает с быстрыми EISA-адаптерами. При обмене 32-битных
- устройств с 32-битной памятью позволяет развить скорость обмена до 33 Мбайт/с.

  В РСІ-системах для обмена с устройствами системной пла-
- ты (Fast ATA-2 или E-IDE-порты) возможно использование DMA Туре F, при котором между соседними циклами интервал не должен превышать 3 тактов шины (360 нс). Для разгрузки системной шины используется 4-байтный

буфер. Режим F может работать только в режиме одиночной передачи или по запросу и исключительно с инкрементом адреса. На самой шине PCI адаптеры могут использовать режим прямого управления шиной, для чего имеется специальный протокол арбитража.

| Номер канала DMA#                                |              | 0            | 1             | 2      | 3    | 4             | 5                  | 6   | 7   |  |
|--------------------------------------------------|--------------|--------------|---------------|--------|------|---------------|--------------------|-----|-----|--|
| Стандартное                                      | XT           | MRFR*        | _             | FDD    | HDD  | Отсутств      | уют                | .i  |     |  |
| назначение                                       | AT           |              | SDLC*         | FDD    | HDD* | Каскад        | <u> </u>           | -   | T-  |  |
| Разрядность, байт                                |              | 1            | 1             |        |      |               | 2 с четного адреса |     |     |  |
| Максимальный размер блока                        |              | 64 Кбайт     | 64 Кбайта     |        |      |               | 128 Кбайт, четный  |     |     |  |
| Граница блока                                    |              | Кратна 1     | Кратна 1000h  |        |      |               | Кратна 2000h       |     |     |  |
| Регистр страниц                                  |              | 4 бит А1     | 4 бит А16-А19 |        |      | 7 бит А17-А23 |                    |     |     |  |
| Адреса регистров:                                |              |              |               |        |      |               |                    |     |     |  |
| страниц                                          |              | 087          | 083           | 081    | 082  | 08F           | 08B                | 089 | 087 |  |
| начального адреса (W)<br>текущего адреса (R)     |              | 000          | 002           | 004    | 006  | 0C0           | 0C4                | 0C8 | 0CC |  |
| начального счетчика (W)<br>текущего счетчика (R) |              | 001          | 003           | 005    | 007  | 0C2           | 0C6                | 0CA | 0CE |  |
| * SDLC-адаптер<br>HDD-контролл<br>Канал 0 в XT и | tep в AT DMA | обычно не ис | •             | MRFR). |      |               |                    |     |     |  |

Канал 4 доступен только в PS/2 MCA.

#### А.5. Обмен данными

различных адаптеров расширения. Чаще всего ПО общается с адаптерами через порты ввода/вывода, используя прерывания, прямой доступ к памяти и непосредственное управление шиной. Связь через область памяти, к которой приписан адаптер, для «нештатных» адаптеров применяется редко. Выбор способа связи определяется пропускной способностью, временем отклика на события, происходящие в адаптере, и допустимой загрузкой процессора.

Открытая архитектура РС предрасполагает использование

Программно-управляемый обмен подразумевает следующие лействия:

- операцию чтения регистра состояния устройства для анализа его готовности;
- ожидание готовности (зацикливание предыдущего шага);

обмен байтом или словом данных. Такой обмен сильно загружает процессор, особенно если программа формирует управляющие сигналы обмена. Так, например, работает драйвер параллельного порта в стандартном режиме, когда строб данных формируется двумя инструкциями ОИТ. В результате пропускная способность такого порта в зависимости от процессора может быть порядка 150 Кбайт/с. Если разгрузить процессор от анализа готовности и формирования строба, как, например, в ЕРР-режиме параллельного порта, то производительность порта можно повысить на порядок. Такой режим обмена программно-управляемым называть некорректно — это режим программного ввода/вывода с аппаратным контролем потока, где темп обмена определяет подключенное устройство. Высокоскоростные режимы РІО применяются в интерфейсе IDE. Они используют инструкции блочной пересылки REP INS/OUTS, при которых процессор пересылает данные между портом и областью памяти за минимальное количество тактов системной шины. Поскольку такую скорость ПУ обычно не воспринимают, контроллер интерфейса «притормаживает» обмен до разумных скоростей, определяемых режимом обмена. Параметры этих режимов,

называемых PIO Mode, приведены в табл. 6.10.

стандартных каналов DMA. Прогрессивные режимы DMA обеспечивают более высокие скорости обмена: Ultra DMA до 33 Мбайт/с. Обсудим теперь инициализацию и синхронизацию. Инициатором обмена выступает или ПО, или ПУ. Программа ожидает какого-либо события в ПУ, периодически читая его регистр состояния. Такой способ называется обменом по опросу готовности. Время реакции может составлять доли микросекунды, когда программа опрашивает устройство монопольно. Однако при этом процессор загружен бесполезной работой. Другой подход - использование аппаратных прерываний, вырабатываемых устройством по событиям, требующим внимания программы. Программные обработчики аппаратных прерываний инициализируют блочный обмен или выполняют одиночную операцию пересылки. Время реакции зависит от множества факторов, включая режим работы процессора. В защищенном режиме прерывание приводит к автоматическому сохранению контекста задачи в стеке и переключению задач. Эти действия связаны с интенсивным обменом с памятью, так что отклик может достигать десятков микросекунд или гораздо больше, если задействована виртуальная память. В реальном режиме процессора ответ на прерывание приходит за единицы микросекунд. Возможно комплексное решение - опрос готовности уст-

ройств по периодическим прерываниям, например, от системного таймера — polling. Готовое устройство обслуживается, неготовое — пропускается до следующего прерывания. Процессор не выполняет бесполезных циклов опроса, а занимается другими задачами. Правда, расходы на обслужи-

Обмен по прямому доступу к памяти (как и режим прямого управления шиной) в наименьшей степени загружает процессор — он занимается лишь анализом состояния и инициализацией канала DMA, но не передачей данных. Время отклика на запрос, когда контроллер «заряжен» на обмен, не превышает сотен наносекунд. Однако скорость стандартного канала DMA ограничена значением 2/4 Мбайт/с в зависимости от разрядности канала. Производительность в режимах прямого управления шиной обычно выше, чем у

на событие не может быть меньшим, чем период таймера. Так работает утилита фоновой печати PRINT.

Активное использование прерываний характерно для мно-

вание прерываний остаются, а максимальное время реакции

гозадачных ОС. **А.6. Распределение системных ресурсов** 

свои системные ресурсы — области адресов в пространствах памяти и ввода/вывода, линии запросов прерываний и каналы прямого доступа к памяти. Платы не должны конфликтовать по ресурсам. Задача конфигурирования осложняется из-за отсутствия общего механизма автоматической передачи установленных параметров прикладному и систем-

# Спецификация ISA требует, чтобы всем картам назначались

ному ПО. Конфигурирование адаптеров выполняется переключением джамперов, затем установленные параметры заносятся в конфигурационные файлы. Применение энергонезависимой памяти (NVRAM или ее разновидности — EEPROM), хранящей настройки, облегчает конфигурирование. С соответствующими адаптерами поставляется утилита настройки. Отсюда их названия: Software Configured (программно конфигурируемые) или Jumperless (без джамперов). Утилита может проверить выбираемые установки на отсутствие конфликта, однако достоверность обнаружения конфликта относительна. Некоторые программно конфигурируемые адаптеры все же имеют джамперы, что бывает полезно для установки типовой настройки, устраняющей конфликты (например, наложение областей памяти сетевого адаптера и видеопамяти). Преимуществом NVRAM является также отсутствие необходимости в конфигураци-

Ключевым моментом в автоконфигурировании является изоляция карты от остальных. Тогда ПО конфигурирования сможет вести с картой диалог, на который не влияет присутствие других устройств. Изоляция карт при конфигурировании заложена в шины МСА, PCI и EISA. В EISA для каждого слота возможно программное селективное управле-

онных файлах.

мо также обеспечить единый метод двухстороннего обмена конфигурационной информацией между картой и ПО. В шину РСІ автоматическое конфигурирование установленных адаптеров заложено изначально. Здесь конфигурированию также подлежат мосты шины (PCI Bridge) — аппарат-

ные средства подключения PCI к другим шинам. *Host Bridge* — главный мост — используется для подключения к

ние сигналом AEN, запрещающим дешифрацию адресов портов ввода/вывода. В системе с шиной EISA имеется энергонезависимая память конфигурирования слотов. Необходи-

системной шине. Peer-to-Peer Bridge — одноранговый мост — используется для соединения двух шин PCI (дополнительные шины PCI позволяют увеличить количество подключаемых устройств). При конфигурировании мостов указывается распределение системных ресурсов по шинам, которые они связывают. Таким образом, задаются пути транслирования управляющих сигналов по шинам и управление буферами данных, обеспечивая для каждого адреса памяти или ввода/вывода единственную шину назначения, по крайней мере для операций чтения (операции записи могут быть широковещательными). Подобная «маршрутизация» необ-

ходима и для сигналов запросов прерываний (каналы DMA к шине PCI отношения не имеют). Среди устройств PnP (для шин ISA и PCI) выделяется класс динамически конфигурируемых устройств *DCD* (*Dynamically Configurable Device*). Ресурсы, используемые ими, динамически переназначаются, не требуя перезагрузки OC. Если

устройство DCD находится в заблокированном состоянии (Locked DCD), его ресурсы не могут быть изменены. Полная поддержка PnP предусматривает наличие PnP BIOS,

Полная поддержка PnP предусматривает наличие PnP BIOS, плат расширения PnP и/или модулей на системной плате. Для хранения информации о системных ресурсах необходи-

Для хранения информации о системных ресурсах необходимо было стандартизовать способы представления конфигурации. В декабре 1994 года компании Compaq, Intel и Phoenix опубликовали версию 1.03 документа «Extended System

Configuration Data Specification» («Спецификация расширенных данных о системной конфигурации»), определяющего методы взаимодействия и структуры данных памяти для

определены для виртуальных (не связанных с конкретным физическим слотом шины) устройств. В ESCD сохранено примерно то же назначение слотов. Так устройства шины PCI (включая мосты) описываются слотами 16–64. С данными ESCD взаимодействует PnP BIOS, а также ОС, поддерживающая PnP. ACFG BIOS (Auto-Configuration BIOS) имеет поддержку PnP, в частности автоконфигурирование. Конфигурированием устройств DCD, которые не были скон-

фигурированы ACFG BIOS во время POST, занимается менеджер конфигурирования, являющийся частью системного ПО. Каждая PnP-плата сообщает менеджеру конфигурирования о потребностях и возможных диапазонах настройки ресурсов. Для обычных (Legacy) плат ISA информация в ESCD заносится с помощью диалоговой утилиты конфигурирования *ICU* (ISA Configuration Utility). Таким образом, конфигурирование плат PnP выполняется автоматически, а

конфигурации устройств *ESCD*. Данные ESCD хранятся в энергонезависимом хранилище информации *NVS* (Non-Volatile Storage). Это может быть память NVRAM или файл данных для ISA-систем, не имеющих поддержки PnP. NVRAM может отображаться на область (верхней) памяти, как полностью, так и постранично. Способ доступа к ESCD определяется вызовом специальной функции PnP BIOS. ESCD разрабатывалась на основе форматов описания устройств шины EISA, в которой имеется специальная энергонезависимая память и утилиты конфигурирования *ECU* (EISA Configuration Utility). Все устройства описываются через *слоты* — специальные структуры данных. В стандарте EISA слот 0 используется для описаний устройств ISA, размещенных на системной плате. Слоты 1–15 соответствуют физическим слотам расширения шины EISA, слоты 16–64

**A.7. Спецификация PnP для шины ISA**Для изоляции карт ISA, программного распределения системных ресурсов, конфигурирования и передачи параметров ОС и прикладному ПО компаниями Intel и Microsoft была

выработана спецификация «Plug and Play ISA Specification»;

обычных карт — джамперами или утилитами.

Конфигурирование в системе PnP состоит из следующих шагов: Производится изоляция одной карты от всех остальных. Карте назначается CSN (Card Select Number).

83

версия 1.0а была опубликована в мае 1994 года. Рассмотрим реализацию PnP с точки зрения аппаратных средств.

С карты считываются данные о сконфигурированных и поддерживаемых ресурсах.

Эти шаги повторяются для всех карт, после чего: производится распределение системных ресурсов, выде-\* ляемых каждой карте;

каждая карта конфигурируется согласно выбранному распределению ресурсов и переводится в рабочий режим. Все шаги конфигурирования выполняет POST, если BIOS име-

ет поддержку PnP, или ОС при загрузке. PnP BIOS может

ограничиться конфигурированием и активацией устройств, участвующих в загрузке. BIOS без поддержки PnP может использовать необходимые для загрузки устройства, сконфигурированные с параметрами по умолчанию, а всем остальным занимается ОС. Конфигурирование выполняется в специальном состоянии плат, в которое их можно программно перевести специальным ключом инициализации, защищающим конфигурационную информацию от случайного разрушения.

Для конфигурирования карт PnP необходимы три 8-битных системных порта (табл. А.4), с которыми процессор общается по инструкциям ввода/вывода с однобайтной передачей данных. Карты PnP должны использовать 12-битное декодирование адреса ввода/вывода, а не 10-битное, как в традиционных картах ISA.

Порт ADDRESS используется для адресации регистров PnP, запись в него производится перед обращением к портам WRITE DATA и READ DATA. Он же применяется для записи последовательности кодов ключа инициализации. Выбор адреса для него обусловлен тем, что «разумные» карты расширения не будут использовать для записи адрес регистра

состояния стандартного LPT-порта.

ционными картами с 10-битным декодированием будет восприниматься как адрес предыдущего порта, так что конфликт исключен. Перемещаемому адресу порта *READ DATA* ПО PnP во время протокола изоляции может легко найти бесконфликтное положение. Адрес этого порта сообщается всем картам записью в их управляющий регистр PnP.

Порты WRITE DATA и READ DATA используются для обмена данными с регистрами PnP. Адрес порта WRITE DATA тради-

# Таблица А.4. Системные порты ISA PnP

Имя порта

| ADDRESS    | 0279h (Printer status port)              | Только запись    |
|------------|------------------------------------------|------------------|
| WRITE_DATA | 0A79h (Printer status port + 0800h)      | Только запись    |
| READ_DATA  | Перемещаемый в диапазоне 0203h-<br>03FFh | Только чтение    |
| В конфито  | опионицій ремим догика DnD г             | IEDEDONUTCO VIII |

Тип доступа

В конфигурационный режим логика PnP переводится ключом инициализации (Initiation key). Ключ представляет со-

бой предопределенную последовательность записей в порт ADDRESS. Аппаратная логика карты, проверяющая ключ, основана на сдвиговом регистре с обратными связями LFSR

рис. А.З. Во время проверки ключа на вход С1 подается уровень логического 0, а на вход С2 — стробы записи в порт ADDRESS. Логика, не показанная на рис. А.З, сравнивает код в сдвиговом регистре с текущей записью и при несовпадении сбрасывает *LFSR* в исходное состояние (код 6Ah). В это

(Linear Feedback Shift Register), схема которого приведена на

же состояние регистр переводится двумя последовательными записями нулей в порт ADDRESS. Сдвиг в регистре происходит при каждой записи в порт ADDRESS. Если ключ (последовательность из 32 записей требуемых байт) будет

приложен верно, после последней записи логика карты перейдет в режим конфигурирования и подготовится к отработке протокола изоляции. Точная последовательность байт ключа в hex-формате выглядит следующим образом:

6A, B5, DA, ED, F6, FB, 7D, BE, DF, 6F, 37, 1B, 0D, B6, C3, 61, B0, 58, 2C, 16, BB, 45, A2, D1, E8, 74, 3A, 9D, CE, E7, 73, 39,



Протокол изоляции основан на идентификаторе Serial

Identifier, хранящемся в памяти каждой карты PnP. Этот идентификатор представляет собой ненулевое 72-битное число, состоящее из двух 32-битных полей и 8-битного контрольного кода, вычисляемого с помощью регистра LFSR. Первое 32-битное поле представляет собой идентификатор производителя. Второе поле назначается производителем

каждому экземпляру. Здесь может присутствовать серийный номер; для адаптера Ethernet это может быть частью MAC-адреса. Принцип построения идентификатора гарантирует, что в одной системе не могут встретиться две карты с совпадающими идентификаторами. Доступ к идентификатору осуществляется последовательно, начиная с бита 0 нулевого байта идентификатора производителя и заканчивая битом 7 контрольной суммы. Во время передачи идентификатора на вход C1 схемы LFSR поступают текущие биты идентификатора, а на вход C2 — стробы чтения регистра Serial Isolation.

Протокол изоляции программно инициируется в любой момент времени посылкой ключа инициализации, переводящего все карты в конфигурационный режим. В этом режиме каждая карта ожидает 72 пары операций чтения порта *READ\_DATA*. Ответ каждой карты на эти операции определяется значением очередного бита ее идентификатора.

В тактах передачи контрольной суммы ее биты берутся с

выхода сдвигового регистра.

Если текущий бит идентификатора карты имеет единичное значение, ее буфер шины данных в первом чтении пары выводит на шину значение 55h. Если текущий бит нулевой, то

данной итерации изоляции исключается. Если карта в текущей паре управляла шиной или читала шину, но не обнаружила корректных активных ответов других карт, она сдвигает идентификатор на один бит и готовится к приему следующей пары циклов чтения. Эта последовательность выполняется для всех 72 бит идентификатора. В конце процесса останется лишь одна карта. Записью в управляющий регистр ей назначается номер CSN, по которому она будет использоваться в дальнейших операциях. Карта с назначенным CSN в следующих итерациях протокола изоляции не

буфер работает на чтение шины и логика карты анализирует ответ других карт — проверяет наличие комбинации 01 в битах D[1:0] (младшие биты 55h). В следующем цикле чтения пары карта с единичным битом выводит число AAh, а карта с нулевым текущим битом проверяет наличие комбинации 10 в битах D[1:0] (младшие биты AAh). Если карта, просматривающая вывод данных другими картами, обнаружила корректные коды в обоих циклах чтения пары, она в

участвует (на пары чтений не отвечает). Во время протокола изоляции карты не имеют права удлинять шинные циклы с помощью сигнала IOCHRDY, поскольку это привело бы к неопределенности результатов наблюдения за «соседями». Программа конфигурирования проверяет данные, возвращаемые во время пар циклов чтения, и побитно собирает про-

читанный идентификатор. Если в паре приняты байты 55h и AAh, соответствующий бит считается единичным, в других случаях — нулевым. При приеме идентификатора про-

грамма подсчитывает контрольную сумму и сравнивает ее с принятой. Несовпадение или отсутствие среди принятых байт 55h и AAh указывает на то, что выбранный адрес порта READ\_DATA конфликтует с каким-либо устройством. Тогда программа производит итерацию, переместив адрес порта READ DATA в допустимом диапазоне адресов. Если при переборе адресов не удается считать корректного идентификатора, принимается решение об отсутствии карт PnP в си-

стеме (вообще или с неназначенными CSN). Программа должна обеспечить задержку 1 мс после подачи ключа перед первой парой чтений и 250 мкс между парами

00h Регистры управления картой 07h 08h На каждую карту Регистры карты (резерв) 1Fh 20h Спец. регистры карты\* 2Fh

сообщенных картам. Далее общение ПО с картой идет по ее номеру CSN, фигурирующему в командах PnP. Нулевой CSN присваивается картам по программному или аппаратному сбросу и используется как широковещательный адрес. Обращения к регистрам РпР представляют собой операции записи/чтения портов ввода/вывода по адресам WRITE DATA/ READ DATA соответственно. При этом для указания конкретного регистра PnP используется *индекс* — номер регистра, предварительно записанный в регистр ADDRESS. Каждая карта имеет стандартный набор регистров PnP; часть из них относится к карте в целом, а часть — к логическим устройствам (ЛУ), входящим в карту. В любой момент времени в индексном пространстве регистров PnP отображаются общие регистры карты и регистры только одного ЛУ (рис. А.4). Выбор ЛУ, с которым производится общение, осуществляется записью в регистр Logical Device Number.

чтений. Это дает карте время для доступа к информации, которая может храниться в медленных устройствах энерго-

По завершении протокола изоляции ПО имеет список идентификаторов обнаруженных карт и присвоенных им номеров,

независимой памяти.



Рис. A.4. Конфигурационные регистры PnP (\* — определяется разработчиком)

**WAKE[CSN]** — записи байта **CSN** в регистр с индексом 3. Эта операция переводит карту с указанным **CSN** в состояние *Config* (конфигурирование), а остальные карты переходят в состояние *Sleep*. Для карты выполняются операции чтения ее конфигурационной информации (как карты в целом, так и ЛУ) и программирования используемых ресурсов. Программирование каждого ЛУ завершается установкой его бита

активации, после чего оно активизируется на шине ISA. Программирование всей карты завершается переводом ее в состояние Wait for key (ожидание ключа). По окончании конфигурирования все карты PnP должны быть переведены в это состояние — тогда их случайное реконфигурирование

Доступ к регистрам PnP через ключ возможен в любое время. Возможно переназначение CSN «на ходу» — это требуется в устройствах, допускающих динамическое включение/выключение, док-станциях (Docking Stations) и при управ-

будет блокировано 32-байтным ключом.

начинается

команды

С точки зрения системы PnP карта пребывает в некотором состоянии. Состояние *Isolate* используется в протоколе изо-

карты

ляции, описанном выше. Программирование ка

лении энергопотреблением.

Все ЛУ карт PnP должны обеспечивать следующую минимальную функциональность:

Вегистры ресурсов при чтении должны отражать фактические текущие настройки.

Бит активации при чтении должен отражать правдивое

Если программа пытается «навязать» карте неподдерживаемую конфигурацию, устройство не должно активироваться; соответственно, при чтении его флаг активации должен быть сброшен.

состояние активности устройства на шине ISA.

ваться; соответственно, при чтении его флаг активации должен быть сброшен.

Стандартные регистры управления картой (табл. А.5) используются для адресации карты и ее ЛУ, а также для чтения кон-

фигурационной информации (дескрипторов). Дескрипторы ресурсов могут быть считаны побайтно из регистра *Resource Data*. При этом могут использоваться данные в короткой или

длинной форме. Короткая форма (Small Resource Data Type) допускает дескрипторы до 7 байт, длинная форма (Large Resource Data Tupe) — до 64 Кбайт. Форма дескриптора и имя описываемого ресурса определяются первым байтом дескриптора. Его последующие байты описывают требуемые ресурсы и возможные варианты (диапазоны) конфигурирования. Таблица: A.S. Стандартные регистры управления картой PnP Индекс и тип Назначение Регистр Set RD DATA 00h. WO Установка адреса порта для чтения. Port Биты [7:0] задают значение бит [9:2] адреса порта *READ DATA*. Только для записи 01h. RO Serial Isolation Чтение этого регистра в состоянии Isolation приводит к побитному анализу идентификатора Config Control 02h, WO Бит [2] — сброс CSN в 0 Бит [1] — возврат в состояние Wait for Keu Бит [0] — сброс всех ЛУ и перевод конфигурационных регистров в состояние включения питания, но CSN сохраняется. Эти биты не запоминаются, так что необходимости в их программном сбросе нет Wake[CSN] 03h, WO Запись в этот регистр приведет карту записываемым байтом CSN переходу из состояния Sleep в состояние Config (если данные не ну-Запись левые). нулевого переводит все карты в состояние Isolation. Указатель последовательно считываемых байт сбрасывается 04h. RO Resource Data Чтение этого регистра возвращает очередной байт информации о ресурсах. Перед чтением должен опрашиваться регистр Status 05h, RO Status Елиничное Регистр состояния. значение бита [0] указывает на возможность чтения очередного байта

ресурсов

#### Таблица А.5 (продолжение)

| Регистр                                     | Индекс и тип | Назначение                                                                                                                                                                                                                                                               |
|---------------------------------------------|--------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Card Select<br>Number                       | 06h, RW      | Регистр хранения селективного адре-<br>са CSN, обеспечивающего выбор кон-<br>кретной карты командой Wake[CSN]                                                                                                                                                            |
| Logical Device<br>Number                    | 07h, RW      | Выбор текущего ЛУ, к которому отно-<br>сятся все операции обмена конфигу-<br>рационной информацией, проверки<br>диапазона адресов ввода/вывода и ак-<br>тивации. Если карта имеет одно<br>устройство, регистр допускает только<br>чтение и всегда имеет нулевое значение |
| Card Level<br>Reserved                      | 08h-1Fh      | Зарезервированы                                                                                                                                                                                                                                                          |
| Card Level,<br>Vendor Defined               | 20h-2Fh      | Используются по усмотрению производителя                                                                                                                                                                                                                                 |
| Таблеца "А.С. Стеца                         | фина рачинув | удскина (ПРнр                                                                                                                                                                                                                                                            |
| Регистр                                     | Индекс и тип | Назначение                                                                                                                                                                                                                                                               |
| Activate                                    | 30h, RW      | Регистр активации: Бит [0] единичным значением разрешает активность ЛУ на шине ISA. Биты [7:1] зарезервированы, при чтении должны возвращать нули. Перед активацией проверка диапазона адресов ввода/вывода должна быть запрещена                                        |
| I/O Range<br>Check                          | 31h, RW      | Регистр проверки диапазона адресов ввода/вывода: Биты [7:2] зарезервированы, при чтении должны возвращать нули Бит [1] — разрешение проверки Бит [0] — управление диагностическим ответом: 0 — ответ AAh, 1 — ответ 55h                                                  |
| Logical Device<br>Control<br>Reserved       | 32h-37h      | Зарезервированы                                                                                                                                                                                                                                                          |
| Logical Device<br>Control Vendor<br>Defined | 38h-3Fh      | Используются по усмотрению производителя                                                                                                                                                                                                                                 |

вывода. Когда включен режим проверки конфликтов, на чтение по любому адресу установленного диапазона портов ввода/вывода ЛУ отвечает байтом 55h или AAh в зависимости от состояния бита 0 регистра проверки диапазона адресов. В рабочем режиме этот «автоответчик» отключен. Оперативные данные конфигурирования доступны через регистры ЛУ. Каждое логическое устройство имеет собственные дескрипторы используемых системных ресурсов: Обычные 24-битные (4) и 32-битные (4) дескрипторы памяти. Поля базового адреса и длины неиспользуемого дескриптора памяти должны быть нулевыми. Одна кар-

Стандартные регистры управления ЛУ (табл. А.6) используются для активации карт и проверки отсутствия конфликтов на шине ISA в выбранном диапазоне адресов ввода/

та не может одновременно использовать 24-битные и 32-битные дескрипторы памяти. Дескрипторы областей портов ввода/вывода (8). Поле базового адреса неиспользуемого дескриптора портов ввода/вывода должно быть нулевым. Размер области адре-

сов определяется в блоке данных описателя. Дескрипторы запросов прерываний (2). Неиспользуемый селектор запроса прерывания должен быть нулевым (нулевой номер запроса занят системным таймером). Для линии IRQ2/9 шины ISA применяют номер 2.

Дескрипторы каналов прямого доступа к памяти. Неиспользуемый дескриптор канала должен иметь значение 4 (этот канал недоступен — используется для каскадирования контроллеров).

Назначение регистров дескрипторов и их положение в индексном пространстве PnP описано в табл. А.7.

#### Таблица А.7. Дескрипторы системных ресурсов ПУ Индекс и тип Назначение 40h-5Fh — Обычные дескрипторы памяти 40h, RW Дескриптор памяти 0: базовый адрес памяти, биты [23:16]

#### Таблица А.7 (продолжение)

| Индекс и тип          | Назначение                                                                                                                                                                                              |
|-----------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 41h, RW               | Дескриптор памяти 0: базовый адрес памяти, биты [15:8]                                                                                                                                                  |
| 42h, RW               | Дескриппор памяти 0: управление. Бит [1] — режим обращения: 0 — 8 бит, 1 — 16 бит. Бит [0] (RO) — способ задания диапазона: 0 — следующее поле воспринимается как размер области, 1 — как старший адрес |
| 43h, RW               | Дескриптор памяти 0: размер или старший адрес области, биты [23:16]                                                                                                                                     |
| 44h, RW               | Дескриптор памяти 0: размер или старший адрес области, биты [15:8]                                                                                                                                      |
| 45h-47h               | Заполнитель (зарезервировано)                                                                                                                                                                           |
| 48h-4Ch               | <i>Дескриптор памяти</i> 1 (аналогично предыдущему)                                                                                                                                                     |
| 4Dh-4Fh               | Заполнитель (зарезервировано)                                                                                                                                                                           |
| 50h-54h               | Дескриптор памяти 2 (аналогично предыдущему)                                                                                                                                                            |
| 55h-57h               | Заполиштель (зарезервировано)                                                                                                                                                                           |
| 58h-5Ch               | Дескриптор памяти 3 (аналогично предыдущему)                                                                                                                                                            |
| 5Dh-5Fh               | Заполнитель (зарезервировано)                                                                                                                                                                           |
| 60h-6Fh — <i>Деск</i> | рипторы пространства ввода/вывода                                                                                                                                                                       |
| 60h, RW               | Дескриттор портов 0: базовый адрес, биты [15:8].<br>Если ЛУ использует только 10-битное<br>декодирование адреса, биты [15:10] могут<br>игнорироваться                                                   |
| 61h, RW               | <i>Дескриптор портов 0</i> : базовый адрес, биты [7:0]                                                                                                                                                  |
| 62h-63h, RW           | <i>Дескриптор портов 1</i> — аналогично                                                                                                                                                                 |
| 64h-65h, RW           | <i>Дескриптор портов 2</i> — аналогично                                                                                                                                                                 |
| 66h-67h, RW           | <i>Дескриптор портов 3</i> — аналогично                                                                                                                                                                 |
| 68h-69h, RW           | <i>Дескриттор портов 4</i> — аналогично                                                                                                                                                                 |
| 6Ah-6Bh, RW           | <i>Дескриптор портов 5 —</i> аналогично                                                                                                                                                                 |
| 6Ch-6Dh, RW           | <i>Дескриптор портов 6</i> — аналогично                                                                                                                                                                 |
| 6Eh-6Fh, RW           | Дескриптор портов 7— аналогично                                                                                                                                                                         |
|                       |                                                                                                                                                                                                         |

| Индекс и тип                              | Назначение                                                                                                                                                                                                                                                                                                                                                                              |  |
|-------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| 70h-73h — Дескрипторы запросов прерываний |                                                                                                                                                                                                                                                                                                                                                                                         |  |
| 70h, RW                                   | Селектор запроса прерывания 0: Биты [3:0] задают номер линии IRQ                                                                                                                                                                                                                                                                                                                        |  |
| 71h, RW                                   | Тип сигнала запроса прерывания 0: Бит[1] — активный уровень: 1 — высокий, 0 — низкий Бит[0] — тип: 1 — уровень, 0 — перепад Если карта поддерживает только один тип сигнала, регистр может быть типа RO                                                                                                                                                                                 |  |
| 72h, RW                                   | Селектор запроса прерывания 1                                                                                                                                                                                                                                                                                                                                                           |  |
| 73h, RW                                   | Тип сигнала запроса прерывания 1                                                                                                                                                                                                                                                                                                                                                        |  |
| 74h-75h — Деска                           | оипторы каналов прямого доступа                                                                                                                                                                                                                                                                                                                                                         |  |
| 74h, RW                                   | Селектор 0 канала DMA. Биты [2:0] задают номер используемого канала (001 — DMA0, 111 — DMA7)                                                                                                                                                                                                                                                                                            |  |
| 75h, RW                                   | Селектор 1 канала DMA                                                                                                                                                                                                                                                                                                                                                                   |  |
| 76h-A8h - 32-6a                           | итные дескрипторы памяти                                                                                                                                                                                                                                                                                                                                                                |  |
| 76h, RW                                   | 32-битный дескриптор памяти 0: базовый адрес памяти, биты [31:24]                                                                                                                                                                                                                                                                                                                       |  |
| 77h, RW                                   | 32-битный дескриптор памяти 0: базовый адрес памяти, биты [23:16]                                                                                                                                                                                                                                                                                                                       |  |
| 78h, RW                                   | 32-битный дескриптор памяти 0: базовый адрес памяти, биты [15:8]                                                                                                                                                                                                                                                                                                                        |  |
| 79h, RW                                   | 32-битный дескриптор памяти 0: базовый адрес памяти, биты [7:0]                                                                                                                                                                                                                                                                                                                         |  |
| 7Ah, RW                                   | 32-битный дескриттор памяти 0: управление Биты [7:3] — зарезервированы, при чтении должны возвращать нули Биты [2:1] — управление доступом: 00 — 8-битная память, 01 — 16-битная память, 10 — зарезервировано, 11 — 32-битная память Бит [0] (RO) — способ задания диапазона: 0 — следующее поле воспринимается как размер области, 1 — следующее поле воспринимается как старший адрес |  |

| аблица A.7 ( <i>пр</i> с | ACOTROGRA)                                                     |
|--------------------------|----------------------------------------------------------------|
| Индекс и тип             | Назначение                                                     |
| 7Bh, RW                  | 32-битный дескриптор памяти 0: размер или старший адрес област |

|         | размер или старший адрес области, биты [31:24]                                |
|---------|-------------------------------------------------------------------------------|
| 7Ch, RW | 32-битный дескриптор памяти 0: размер или старший адрес области, биты [23:16] |
| 7Dh RW  | 32-humunii decummon navami ()                                                 |

7Dh, KW -битный дескриптор памяти 0: размер или старший адрес области, биты [15:8] 7Eh, RW 32-битный дескриптор памяти 0: размер или старший адрес области, биты [7:0]

7Fh Заполнитель (зарезервировано) 80h 88h 32-битный дескриптор памяти 1

89h-8Fh Заполиштей (зарезервировано)

90h-98h 32-битный дескриптор памяти 2

99h-9Fh Заполнитель (зарезервировано)

32-битный дескриптор памяти 3 A0h-A8h

# Приложение Б. Элементы цифровой схемотехники

рых полезно для работы с интерфейсами.

пользуются логические вентили на ТТЛ (TTL) и КМОП (CMOS) структурах. Внутри сложных микросхем применяются и другие типы ячеек, но они обычно обрамляются внешними схемами с параметрами ТТЛ- или КМОП-вентилей. Приведем некоторые свойства этих вентилей, знание кото-

В полупроводниковых цифровых микросхемах широко ис-

Логические микросхемы, применяемые в компьютерах, питаются от постоянного напряжения +5 В, приложенного относительно общего провода — шины GND. В современных компонентах (процессорах, микросхемах памяти) стремятся снизить напряжение питания до 3,3 В и ниже.

Существует несколько разновидностей микросхем ТТЛ. Стандартные микросхемы серий 74ххх имеют среднее потребление и быстродействие 10 нс, их отечественные аналоги — серии К155 и К133. Микросхемы с пониженным потреблением серии 74Lххх и их аналоги К134 имеют пониженное быстродействие (33 нс). Серии 74Hххх (К131), напротив, имеют повышенную выходную и потребляемую мощность. Микросхемы с диодами Шотки (ТТЛШ) 74Sххх (К531) при более высо-

ком, чем у стандартных, энергопотреблении имеют быстродействие в три раза выше (3 нс). Серия маломощных микросхем ТТЛШ 74LSxxx (К555) при том же быстродействии, что и у стандартной, потребляет мощность в несколько раз меньше. Наиболее перспективными являются серии 74Fxxx (КР1531) с быстродействием 3 нс и 74ALSxxx (КР1533) с быстродействием 4 нс. При этом потребление у серии ALS (Advanced Low-Power Schottky) в два раза ниже, чем у серии F (Fast).

Серия ALS хорошо стыкуется с микросхемами КМОП. В ТТЛ-логике различают входы, выходы (обычные, тристабильные и с открытым коллектором) и двунаправленные выводы.

сокоуровневое, и на нем высокоомным вольтметром или осциллографом можно наблюдать потенциал 1,3–1,4 В. В таком состоянии вход является чувствительным к помехам, поэтому свободные входы рекомендуют соединять с источником высокого или низкого логического уровня (в зависимости

от логики работы). Если несколько свободных входов разных вентилей соединяются вместе, их состояние будет неопределенным: из-за разброса порогов часть из них может восприниматься как высокий уровень, а часть — как низкий.

Вход ТТЛ воспринимает только логический уровень сигнала. Порог переключения — обычно 1,3–1,4 В. Напряжение ниже порога воспринимается как низкий уровень, выше — как высокий. Состояние свободного (ни к чему не подключенного) входа ТТЛ-микросхемой воспринимается как вы-

В качестве источника высокого уровня часто используют шину питания +5 В, но вход (или группу входов) подключают к ней через балластный резистор (1–10 кОм). В качестве низкого уровня используют общий провод (шину GND). Входной ток зависит от потенциала входа: при низком уровне ток имеет отрицательное значение (вытекающий ток) порядка 1,5 мА для стандартных микросхем ТТЛ, при высоком

уровне — положительное (втекающий ток) на уровне десятков микроампер. У микросхем серий S, LS и ALS входные токи существенно меньше. Входное напряжение, превыша-

ющее значение питающего напряжения, для микросхем ТТЛ недопустимо — оно может пробить входной вентиль. Кроме вентилей с обычными входами существуют вентили с триггерами Шмитта. У них имеется гистерезис переключения около 0,8 В, симметричный относительно порога (1,3 В). Эти элементы используются как приемники сигналов с повышенным уровнем помех.

ным уровнем помех.

Обычный выход ТТЛ формирует выходные логические уровни: низкий (ниже 0,4-0,5 В) и высокий (выше 2,4 В). Выходные уровни при повышении нагрузки (выходного тока)

ухудшаются — приближаются к порогу переключения. Выходной ток короткого замыкания (КЗ) на землю ограничен несколькими миллиамперами, поэтому КЗ на землю безопасно для выходов элементов ТТЛ. Выходной ток при КЗ

на шину питания, когда вентиль пытается формировать низ-

тью. Они предназначены для подключения большого количества входов или цепей с большой емкостной нагрузкой. В РС таким местом является, например, мультиплексированная шина адреса динамической памяти. Выход с открытым коллектором (Open Drive Output) работает в качестве ключа, способного коммутировать сигнал на шину GND. Этот тип выхода способен формировать только низкий логический уровень, а высокий уровень формируют с помощью внешнего резистора, «подтягивающего» сигнал к напряжению питания (Pullup Resistor). Выходы с открытым коллектором разрешается объединять, при этом реализуется функция «монтажное И». Существуют элементы с открытым коллектором, имеющие повышенную нагрузочную способность как по допустимому выходному току ключа, так и по допустимому напряжению на закрытом ключе. Они могут использоваться для управления исполнительными устройствами (например, реле), индикаторами и т. п. Тристабильный выход (Tristate Output) кроме формирования низкого и высокого уровней может быть переведен в третье, высокоимпедансное (High-Z State) состояние, в котором выходной вентиль отключен от вывода. Этот тип выхода предназначен для объединения нескольких источников сигнала на одной шине. Как правило, не в третьем состоянии может

кий уровень сигнала, достигает десятков миллиампер и опасен для микросхемы. Если два выхода соединить вместе и они будут пытаться формировать разные уровни, то в этом конфликте «победит» выход, формирующий низкий логический уровень. Этим свойством иногда пользуются при построении схем, но это не совсем «законно». Существуют буферные элементы с повышенной нагрузочной способнос-

Двунаправленный вывод элемента представляет собой комбинацию входа и тристабильного выхода (или выхода с открытым коллектором). В зависимости от управляющего сигнала этот вывод работает либо как вход, либо как выход.

OE (Output Enable).

находиться не более одного из объединяемых источников. В противном случае на шине будет конфликт, в котором побеждает низкий уровень. Вентили с тристабильным выходом имеют управляющий вход, который обычно обозначают

размахом сигнала (низкий уровень ближе к нулю, высокий — к напряжению питания), малыми входными токами (почти нулевыми в статике, в динамике — обусловленными паразитной емкостью) и малым потреблением, однако их быстродействие несколько ниже. В отличие от ТТЛ, микросхемы

КМОП допускают более широкий диапазон питающих напряжений. Микросхемы ТТЛ и КМОП взаимно стыкуются,

Логические элементы КМОП отличаются от ТТЛ большим

хотя вход КМОП требует более высокого уровня логической единицы, а выход КМОП из-за невысокого выходного тока можно нагружать лишь одним ТТЛ-входом. Современные микросхемы КМОП по параметрам приближаются к ТТЛ серии ALS и хорошо стыкуются с ними. Микросхемы КМОП имеют те же типы выводов, но вместо выхода с открытым коллектором у них присутствует выход с открытым стоком (что по логике работы одно и то же). Длина интерфейсных кабелей ограничивается как уровнем помех на входе, так и создаваемой емкостной нагрузкой на

Длина интерфейсных кабелей ограничивается как уровнем помех на входе, так и создаваемой емкостной нагрузкой на выходные вентили, в качестве которых рекомендуется применять элементы с повышенной нагрузочной способностью. Длина кабелей *Centronics* ограничена несколькими метрами, в то время как для интерфейса *RS-232C* допустимы кабели длиной в десятки метров (сказывается большая разница уровней и зона нечувствительности). Логические схемы могут быть чисто комбинационными вентилями (*Gate*), у которых состояние выходов определяется только текущим состоянием входов, или элементами с па-

только текущим состоянием входов, или элементами с памятью. В схемах последнего типа состояние выхода определяется предысторией входных сигналов и внутренних состояний. К ним относятся разнообразные тригтеры, регистры, счетчики и т. п. Элементы могут быть асинхронными и синхронными. У последних состояние входов стробируется потенциалом или перепалом на специальном входе синхрони-

хронными. У последних состояние входов стробируется потенциалом или перепадом на специальном входе синхронизации. Следует особо отметить два типа элементов, широко применяемых в микропроцессорной технике. Регистром (Register) называют совокупность нескольких запоминающих

(Register) называют совокупность нескольких запоминающих элементов, запись в которые производится по общему управляющему сигналу. Подразумевается, что в регистре информация воспринимается по перепаду сигнала синхрони-

ном состоянии управляющего входа (высоком) регистр «прозрачен» — на выходе отражаются изменения на входах, а при переходе этого сигнала в другое состояние на выходах фиксируется состояние, присутствующее к этому моменту. Защелки используются для фиксации адреса на шине микропроцессора, позволяя схемам дешифраторов адреса раньше начинать работу, тем самым сокращая затраты времени на дешифрацию адреса. До срабатывания на выходе защелки возможен «мусор» от переходных процессов на входе, чего

зации (на рис. Б.1а запись происходит по положительному перепаду). Защелкой (Latch), или регистром-защелкой, называют схему, работающую иначе (рис. Б.16). Здесь при од-

не бывает в регистрах, синхронизируемых по перепаду. Для того чтобы любая синхронизируемая схема зафиксировала желаемое состояние, сигналы на входах должны установиться до синхронизирующего перепада за некоторое время, называемое временем установки Т<sub>SETUP</sub>, и удерживаться после него в течение времени удержания Т<sub>HOLD</sub>. Значение этих параметров определяется типом и быстродействием синхронизируемой схемы, и в пределе один из них может быть нулевым.



**Рис. Б.1.** Диаграмма работы регистров: а — регистр, б — регистр-защелка

Наконец, рассмотрим типовое подключение некоторой функциональной микросхемы (например, i8255 — KP580BB55) к

жения устройств микропроцессорной техники (рис. Б.2). Для сопряжения с микропроцессором имеется шина данных (Data Bus), шина адреса (Address Bus) и шина управления (Control Bus). Первые две из них могут использовать одни и те же

шине ISA, которое хорошо иллюстрирует принципы сопря-

виз). Первые две из них могут использовать одни и те же физические линии, такое решение называется мультиплек-

сированием шины адреса и данных. Тогда в шине управления будет присутствовать сигнал, определяющий назначение шины в данный момент времени. В нашем примере шины адреса и данных разделены.



Рис. Б.2. Подключение устройства к шине ISA

Подключаемое устройство обычно имеет свой буфер данных — двунаправленный приемопередатчик, в качестве ко-

торого применяется микросхема 74ALS245 (1533AП6). Буфер должен открываться сигналом ОЕ# (Output Enable — разрешение выхода), когда на шине адреса присутствует адрес, относящийся к диапазону подключаемого устройства. «Дежурным» направлением передачи является «от шины — к устройству»; переключение в обратную сторону производится по сигналу IORD# шины управления. Таким образом, буфер имеет право передавать данные на шину (управлять шиной данных) только во время действия сигнала чтения, относящегося к зоне адресов данного устройства. Если бы подключаемое устройство было приписано к пространству памяти, в логике управления направлением присутствовал бы сигнал МЕМВО#.

Дешифратор адреса предназначен для выявления зоны адресов, относящейся к подключаемому устройству. Если устройству требуется более одного адреса, младшие линии адреса (в данном примере — A0 и A1) используются для декодирования адреса внутри устройства. Остальные линии поступают на вход комбинационной схемы (или программируемой логической матрицы), которая формирует сигнал

кироваться высоким уровнем сигнала AEN, сигнализирующим о недействительности адреса для порта ввода/вывода в цикле DMA.

Шина управления представлена сигналами IORD# (чтение порта), IOWR# (запись в порт) и AEN. Их состав может быть

обращения к устройству, называемый CS# (*Chip Select*). На шинах ISA срабатывание дешифратора адреса должно бло-

расширен сигналами обращения к памяти MEMRD# и MEMWR#, а также сигналами запросов прерываний, управления каналами прямого доступа и др. Приведенные четыре сигнала обращения к портам и памяти, используемые в шине ISA, характерны для микропроцессорных наборов и периферийных схем i8080. Есть другой набор сиг-

налов — в стиле i8085: сигнал M/IO# определяет, к чему относится обращение — к памяти (М) или вводу/выводу (ІО), сигнал W/R# определяет тип операции — запись (W) или чтение (R), а сама операция осуществляется по некоторому синхронизирующему сигналу. Такой способ применяется в шинах EISA и PCI.

В микропроцессорной технике применяются прямые и инверсные логические сигналы. В случае прямых сигналов логическому нулю соответствует низкий уровень сигнала, логической единице — высокий. В случае инверсных сигналов все наоборот. Инверсию сигналов обозначают разными спо-

собами: перед названием сигнала ставят знак «минус», над именем проводят черту, после имени ставят обратную косую черту или решетку. В данной книге используется последний способ. Управляющие сигналы обычно инверсные.

Это так называемые L(Low)-активные сигналы, у которых активный уровень сигнала— низкий. Это нужно, чтобы:

повысить помехозащищенность, которая у ТТЛ несим-

метричная. Входные токи стремятся подтянуть уровень к высокому, и в случае прямых H(High)-активных сигналов это действует согласно с помехой, чреватой ложными срабатываниями. При L-активных сигналах входной

ток противодействует помехе. Особенно важно использовать L-активность для сигналов, передаваемых по ка-

белям.

выходом). В IBM PC принцип L-активности управляющих сигналов интерфейса был нарушен дважды: Н-активность имеют сигналы запросов аппаратных прерываний IRQх и каналов прямого доступа DRQх. Это привело к невозможности совместного использования линий прерываний и каналов DMA. Обозначение и порядок бит и байт шин адреса/данных пришло от процессоров Intel 8086/88. В шине данных D0 обозначает самый младший бит LSB (Least Significant Bit), а D7 — старший бит байта — MSB (Most Significant Bit). Иногда в описании интерфейсов биты данных обозначаются как D1...D8, при этом младший бит — D1. На рисунках принято старший

обеспечить возможность нескольким источникам управлять одной и той же линией. L-активная линия «подтягивается» к высокому уровню резистором, а активный сигнал может вводить любой подключенный к ней вентиль с открытым коллектором (можно с тристабильным

LH-порядок следования: адрес слова указывает на младший байт L (Low), а старший байт H (High) размещается по адресу, на единицу большему. В двойном слове порядок будет аналогичным — адрес укажет на самый младший байт, после которого будут размещены следующие по старшинству. Этот порядок естествен для процессоров Intel.

бит изображать слева, а младший — справа. Обозначение D[7:0] относится к группе сигналов D7, D6,..., D1, D0, а D[0:7] — к тем же сигналам, но в порядке естественной нумерации. В двухбайтном слове, размещаемом в памяти, принят

порядок естествен для процессоров Intel.

В цифровой схемотехнике есть множество тем для обсуждения, остановимся на том, что уже изложено.

## Приложение В. Конструктивные элементы интерфейсов

Определим некоторые термины, относящиеся к аппаратным средствам современных компьютеров.

Системной (System Board), или материнской, платой (Mother Board) называют основную печатную плату, на которую

устанавливают процессор, оперативную память, ROM BIOS

и другие системные компоненты. Платой или картой расширения (Expansion Card) называют печатную плату с краевым разъемом, устанавливаемую

в слот расширения. Карты расширения, обеспечивающие какой-либо дополнительный интерфейс, называют интерфейсными картами (Interface Card). Их также называют адаптерами (Adapter). К примеру, дисплейный адаптер (Display

adapter) служит для подключения монитора. Слот (Slot) представляет собой щелевой разъем, в который устанавливается какая-либо печатная плата. Слот расширения (Expansion Slot) в РС представляет собой разъем сис-

темной шины в совокупности с прорезью в задней стенке корпуса компьютера — то есть посадочное место для установки карты расширения. Слоты расширения имеют разъемы шин ISA/EISA, PCI, AGP, MCA, VLB или PC Card

Сокет (Socket) — гнездо, в которое устанавливаются микросхемы. Его контакты рассчитаны на микросхемы со штырь-

кациях или же микросхемы в корпусах SOJ и PLCC с выводами в форме буквы «J». ZIF-Socket (Zero Insertion Force — с нулевым усилием вставки) предназначен для легкой установки при высокой надежности контактов. Эти гнез-

да имеют замок, открыв который можно установить или

(PCMCIA). Внутренние слоты используются для установки модулей оперативной памяти (DIMM), кэш-памяти (COAST), процессоров Pentium II и т. д. ковыми выводами в корпусах DIP и PGA во всех модифиизъять микросхему без приложения усилия к ее выводам. После установки замок закрывают, при этом контакты сокета плотно обхватывают выводы микросхемы.

Джампер (Jumper) — съемная перемычка, устанавливаемая на торчащие из печатной платы штырьковые контакты (рис. В.1а). Джамперы используются для конфигурирования различных компонентов, которые не требуют оперативного управления. Джамперы переставляют с помощью пинцета при выключенном питании.



Рис. В.1. Аппаратные средства конфигурирования: а — джампер, б — DIP-переключатель

являются большее занимаемое на плате место и более высокая цена. Обычно являются только выключателями, что делает их применение менее гибким по сравнению с джамперами. Платы (карты), в которых нет джамперов, называют

*DIP-переключатели* (DIP Switch) — малогабаритные выключатели в корпусе DIP (рис. В.16), применяемые для тех же целей, что и джамперы. Более легки в переключении. Недостатками

Платы (карты), в которых нет джамперов, называют *Jumperless Cards*. Компоненты, которые после установки конфигурируются автоматически, относят к классу *PnP* (Plug and Play — вставляй и играй). *Чип* (Chip) — полупроводниковая микросхема. *Чипсет* (Chip.

Yun (Chip) — полупроводниковая микросхема. Yuncem (Chip Set) — набор специализированных интегральных схем, при подключении которых друг к другу формируется функциональный блок вычислительной системы. Чипсеты применяются в системных платах, графических контроллерах и других устройствах, функции которых нельзя реализовать в одной микросхеме.

Для соединения устройств и узлов РС применяют различные *разъемы*, они же *коннекторы* (Connector). Среди них чаше всего встречаются следующие:

мов и т. д. Розетки (Female, «мамы») обозначаются как DB-xxS, где xx - количество контактов. Вилки (Male,«папы») обозначаются как DB-ххР. Ключом является D-образный кожух. Назначение разъемов, выходящих на заднюю стенку РС, стандартизовано (табл. В.1).

**DB-15S** 

(Game)

DB-9S

DB-9P

DB-15S

(VGA)

Разъемы *D-типа* (рис. В.2) используются для подключения внешних устройств — мониторов, принтеров, моде-

DB-25P

**DB-25S** 

| Тип разъема                    | Назначение                        |
|--------------------------------|-----------------------------------|
| DB-9P (вилка)                  | СОМ-порт                          |
| DB-9S (розетка)                | Выход на монитор (Mono, CGA, EGA) |
| DB-15S (розетка)<br>двухрядный | Game-порт, MIDI                   |
| DB-15S (розетка)<br>трехрядный | Выход на монитор (VGA/SVGA)       |
| DB-25P (вилка)                 | СОМ-порт                          |
| DB-25S (розетка)               | LРТ-порт                          |

Рис. В.2. Разъемы D-типа (вид с наружной стороны)

Разъемы *IDC* (Insulation-Displacement Connector — разъем, 88

смещающий изоляцию) получили свое название из-за способа присоединения кабеля. Контакты разъема со стороны, обращенной к кабелю, имеют ножи, подрезающие и

смещающие изоляцию проводников кабеля. Разъемы предназначены для ленточных кабелей шлейфов, хотя возмож-

на заделка в них и одиночных проводников. Для заделки кабелей в эти разъемы существуют специальные инструменты - прессы. Разъемы IDC существуют для краевых печатных разъемов (рис. В.За) и штырьковых контактов (рис. В.36). Разъемы могут иметь ключи: для печатных разъемов это прорезь и соответствующая ей перемычка, расположенная ближе к первым контактам. Для штырьковых разъемов ключом является выступ на корпусе, но этот ключ сработает, только если ответная часть имеет пластмассовый бандаж с прорезью. Ключом может являться отсутствующий штырек — на разъеме для него не оставляют отверстия (такой ключ рекомендуется стандартом АТА). На ленточном кабеле крайний провод, соединяемый с контактом «1», маркируют цветной краской. На печатной плате штырек «1» обычно имеет отличающуюся от других (квадратную) форму контактной площадки. Разъемы IDC и ленточные кабели-шлейфы применяют для подключения внешних разъемов к системной плате и картам расширения и для подключения накопителей.



**Рис. В.З.** Разъемы IDC: a — краевые,  $\delta$  — штырьковые, s — заделка проводов

Разъемы типа *Centronics* (рис. В.4) применяют на принтерах и внешних устройствах SCSI.



Рис. В.4. Разъемы типа Centronics

параметров и помехозащищенности лучшим способом является передача каждого сигнала в дифференциальном виде по отдельной витой паре проводов, но это дорого. Неплохой результат дает линейная (обычная) передача сигнала, но так, чтобы сигнальный провод был перевит с собственным обратным проводом, соединенным с шиной GND на обоих концах интерфейса. Чуть хуже, но дешевле использование плоского кабеля-шлейфа, в котором сигнальные проводники чередуются с «землей» или используются дифференциальные пары. Как правило, чем длиннее соединительный кабель, тем ниже его пропускная способность. Поэтому, если с длинным кабелем возникают проблемы, надо либо менять кабель на более качественный и/или короткий, либо снижать физическую скорость обмена. В маркировке проводов кабелей часто фигурирует обозначение вида 24 AWG. Оно определяет сечение проводника согласно стандарту AWG (American Wire Gauge), как показано в табл. В.2. Таблица В.2. Классификации проводов по AWG

В интерфейсах применяют кабели различных типов — экранированные, неэкранированные, с витыми парами проводов, плоские кабели-шлейфы и т. п. С точки зрения частотных

| Номер<br>по AWG | Диаметр,<br>мм | Сечение,<br>мм <sup>2</sup> | Сопротивление<br>1 нм провода, Ом | Допустимый<br>тон, А <sup>*</sup> |
|-----------------|----------------|-----------------------------|-----------------------------------|-----------------------------------|
| 46              | 0,04           | 0,0013                      | 13700                             | 0,0038                            |
| 44              | 0,05           | 0,0020                      | 8750                              | 0,006                             |
| 42              | 0,06           | 0,0028                      | 6070                              | 0,009                             |
| 41              | 0,07           | 0,0039                      | 4460                              | 0,012                             |
| 40              | 0,08           | 0,0050                      | 3420                              | 0,015                             |
| 39              | 0,09           | 0,0064                      | 2700                              | 0,019                             |
| 38              | 0,10           | 0,0078                      | 2190                              | 0,024                             |
| 37              | 0,11           | 0,0095                      | 1810                              | 0,028                             |
|                 | 0,12           | 0,011                       | 1520                              | 0,033                             |
| 36              | 0,13           | 0,013                       | 1300                              | 0,040                             |
| 35              | 0,14           | 0,015                       | 1120                              | 0,045                             |
|                 | 0,15           | 0,018                       | 970                               | 0,054                             |

### Таблица В.2 (продолжение Диаме Номер

мм

0.16

0.17

0,18

0,19

0.20

0.25

0,30

0.35

0.40

0.45

0,50

0,55

0.60

0,65

0.70

0,75

0,80

0.85

0,90

0,95

1,00

1,10

1,20

1.30

1,40

1,50

1,60

1.70

1,80

1,90

2,00

по AWG

34

------

33

32

30

29

27

26

25

24

-11-

22

20

19

18

-----

----16

--11---

----

14

13

12

-11-

-11-

\_,,\_

| етр, | Сечение<br>мм <sup>2</sup> |
|------|----------------------------|

0.020

0.023

0,026

0.028

0.031

0.049

0.071

0.096

0.13

0,16

0,20

0,24

0.28

0,33

0.39

0,44

0,50

0.57

0,64

0,71

0.78

0.95

1,1

1,3

1,5

1,8

2,0

2,3

2,6

2,8

3,1

\* При допустимой плотности тока 3 А/мм<sup>2</sup>.

844

757

676

605

547

351

243

178

137

108

87,5

72,3

60.7

51,7

44.6

38,9

34,1

30.2

26,9

24,3

21,9

18,1

15,2

13,0

11,2

9,70

8,54

7,57

6,76

6.05

5,47

| Допустимый<br>ток, А <sup>*</sup> |
|-----------------------------------|
| <br>0.06                          |

0.068

0,075

0,085

0.093

0.147

0.212

0.288

0.378

0.477

0,588

0,715

0.85

1,0

1.16

1,32

1,51

1,70

1,91

2,12

2,36

2,85

3,38

3,97

4,60

5.30

6,0

6.7

7,6

8,5

9,4

| ние, | Сопротивление | Допустимый |
|------|---------------|------------|
| ı    |               |            |

# Приложение Г. Проблемы

**Заземления** Вопросы электропитани

Вопросы электропитания играют важную роль в устойчивости работы компьютеров, их сетей и ПУ, соединяемых интерфейсами, а также в обеспечении их долголетия. Понимание некоторых вопросов электротехники позволит обойтись без «пиротехнических эффектов» при соединении устройств. Рассмотрим правила подключения к питающей сети с точки зрения безопасности как человека, так и компьютера.



Рис. Г.1. Входные цепи блока питания

Практически каждый блок питания компьютера или ПУ имеет сетевой фильтр (рис. Г.1). Конденсаторы этого фильтра предназначены для шунтирования высокочастотных помех питающей сети на землю через провод защитного заземления и соответствующую трехполюсную вилку и розетку. «Земляной» провод соединяют с контуром заземления, но допустимо его соединять и с «нулем» силовой сети (разница ощущается только в особо тяжелых условиях эксплуатации). При занулении необходимо быть уверенным в том, что «нуль» не станет фазой, если кто-нибудь вдруг перевернет вилку питания. Если же «земляной» провод устройства никуда не подключать, на корпусе устройства появится напря-

торы фильтра работают как емкостной делитель напряжения, и поскольку их емкость одинакова, 220 В делится пополам.

жение порядка 110 В переменного тока (рис. Г.2): конденса-



**Рис. Г.2.** Образование потенциала на корпусе компьютера Конечно, мощность этого «источника» ограничена — ток ко-

роткого замыкания  $I_{\kappa,s}$  на землю составляет от единиц до десятков миллиампер, причем, чем мощнее блок питания, тем больше емкость конденсаторов фильтра и, следовательно, ток:  $I_{\kappa,s} = U_{\text{nur}} \times 2\pi FC$ .

II 000 1

где  $U_{\text{пит}}$  = 220 В, F = 50 Гц — частота питающей сети, C — емкость конденсатора фильтра. При емкости конденсатора C = 0,01 мк $\Phi$  этот ток будет около 0,7 мА.

Такие напряжение и ток *опасны для человека*. Попасть под напряжение можно, прикоснувшись одновременно к неокрашенным металлическим частям корпуса компьютера и, например, к батарее отопления. Это напряжение является одним из источников разности потенциалов между устрой-

ствами, от которой страдают интерфейсные схемы. Посмотрим, что происходит при соединении двух устройств (компьютера и принтера) интерфейсным кабелем. Общий

провод интерфейсов последовательных и параллельных портов связан со «схемной землей» и корпусом устройства. Если

соединяемые устройства надежно заземлены (занулены) через отдельный провод на общий контур (рис. Г.З), проблемы разности потенциалов не возникает.



**Рис. 1.3.** правильное подключение пр

Если же в качестве заземляющего провода использовать нулевой провод питания при разводке питающей сети с трехполюсными розетками *двухпроводным* кабелем, на нем будет набегать *разность потенциалов*, вызванная падением напряжения от протекающего силового тока I<sub>NUL</sub> (рис. Г.4).



**Рис. Г.4.** Появление разности потенциалов при двухпроводном кабеле питания

Если в эти же розетки включать устройства с большим энергопотреблением, разность потенциалов (и импульсные помехи при включении-выключении) будет ощутимой. При этом эквивалентный источник напряжения при относительно невысокой ЭДС. Епш (несколько вольт) будет иметь очень

стка нулевого провода (доли Ом). Уравнивающий ток через общий провод интерфейса  $I_{INT}$  можно оценить по формуле  $I_{int} = E_{nul}/(R_{nul} + R_{int})$ , где  $E_{nul} = I_{nul} \times R_{nul}$ ,  $I_{nul} = P/220$ ,  $R_{nul}$  — сопротивление нулево-

низкое выходное сопротивление, равное сопротивлению уча-

го провода и соединительных контактов розеток,  $R_{\rm int}$  — сопротивление общего провода интерфейса, P — мощность, потребляемая устройствами, расположенными на рис. Г.4 справа (P = P2 + P3). Поскольку обычно сопротивление интерфейсного кабеля боль-

ше питающего, через общий провод интерфейса потечет ток существенно меньший, чем силовой. Но при нарушении контакта в нулевом проводе питания через интерфейсный провод может протекать и весь ток, потребляемый устройством. Он может достигать нескольких ампер, что повлечет выход устройств из строя. Невыровненные потенциалы корпусов устройств также являются источником помех в интерфейсах.

Если оба соединяемых устройства не заземлены, в случае их питания от одной фазы сети разность потенциалов между

ними будет небольшой (вызванной разбросом емкостей конденсаторов в разных фильтрах). Уравнивающий ток через общий провод интерфейса будет мал, и разность потенциалов между схемными землями устройств тоже будет мала. Но не следует забывать о безопасности человека. Если незаземленные устройства подключены к разным фазам, разность потенциалов между их несоединенными корпусами будет порядка 190 В, при этом уравнивающий ток через интерфейс может достигать десятка миллиампер. Когда все соединения/разъединения выполняются при отключенном питании, для интерфейсных схем такая ситуация почти безопасна. Но при коммутациях

при включенном питании возможны неприятности: если контакты общего провода интерфейса соединяются позже (разъединяются раньше) сигнальных, разность потенциалов между схемными землями прикладывается к сигнальным цепям, и они выгорают. Самый тяжелый случай — соединение заземленного устройства с незаземленным (рис. Г.5), особенно когда у последнего мощный блок питания.

полюсной вилкой, эти проблемы тоже актуальны. Такие блоки питания зачастую имеют сетевой фильтр, но с конденсаторами малой емкости (ток короткого замыкания достаточно мал). Весьма коварны сетевые шнуры компьютеров с двухполюсной вилкой, которыми подключаются блоки питания с трехполюсным разъемом. Пользователи, подключающие свои компьютеры в бытовые розетки, могут столкнуться с проблема-

Для устройств, блоки питания которых имеют шнуры с двух-



Рис. Г.5. Подключение незаземленного устройства Локально проблемы заземления решает применение сетевых

фильтров типа Pilot и им подобных. Питание от одного фильт-

ра всех устройств, соединяемых интерфейсами, решает проблему разности потенциалов. Еще лучше, когда этот фильтр включен в трехполюсную розетку с заземлением (занулением). Однако заземляющие контакты (обжимающие «усики») многих розеток могут иметь плохой контакт вследствие своей слабой упругости или заусениц в пластмассовом кожухе. Кроме того, эти контакты не любят частого вынимания и вставки вилок, так что обесточивание оборудования по окончании работы лучше выполнять выключателем питания фильтра (предварительно выключив устройства).

Настоятельно рекомендуется отключать питание при подключении и отключении интерфейсных кабелей. Небольшая разность потенциалов, которая практически исчезнет при соединении устройств общими проводами интерфейсов, может пробить входные (и выходные) цепи сигнальных линий, если в момент присоединения разъема контакты общего провода соединятся поэже сигнальных. От такой последовательности обычные разъемы не страхуют.

порты. У последовательных портов зона нечувствительности шире (пороги ±3 В), еще меньшую чувствительность имеют интерфейсы локальных сетей, где обычно имеется гальваническая развязка сигнальных цепей от схемной земли с допустимым напряжением изоляции порядка 100 В. Проблема заземления устройств, сильно разнесенных территориально, обостряется. Если разводка питания и заземления выполнена двухпроводным кабелем (см. рис. Г.4), разность потенциалов, обусловленная падением напряжения на заземляющих проводах, будет особенно ощутимой. В ряде случаев практикуется прокладка отдельного кабеля или шины для цепи заземления. Однако разводка заземления отдельным кабелем не всегда удобна и часто неэффективна с точки зрения защиты от помех, поскольку при этом могут образовываться замкнутые контуры с широким охватываемым пространством — своеобразные антенны. Так что разводку питания к устройствам целесообразно выполнять трехпроводным кабелем, один из проводов которого используется для защитного заземления. При этом древовидная схема заземления получается естественным образом (рис. Г.6), защитный провод в корневой части этого дерева заземляют или зануляют. Все устройства, электрически соединяемые между собой, желательно питать от одной фазы сети, хотя, с точки зрения энергетиков, это требование часто трудновыполнимо. Дополнительные проблемы при разводке электропитания для компьютеров обусловлены ярко выраженной динамической нелинейностью входной цепи бестрансформаторных блоков питания. Традиционные электросети рассчитаны на более или менее линейную нагрузку, у которой в спектре тока основная мощность приходится на первую гармонику. В трехфазной сети с равномерно распределенной по фазам линейной нагрузкой в идеале через нейтральный провод ток практически не течет, поскольку токи от нагрузок всех трех фаз компенсируют друг друга. Учитывая это свойство, во многих четырехпроводных кабелях сечение проводника для нейтрали существенно меньше, чем сечение фазных проводников. При нелинейной симметричной нагрузке фаз при большом

К помехам, вызванным разностью потенциалов схемных земель (корпусов) устройств, наиболее чувствительны параллельные

уровне третьей гармоники тока (что характерно для бестрансформаторных блоков питания) взаимной компенсации токов не происходит, и действующее значение тока в нулевом проводе оказывается даже больше, чем в каждом из фазных. Таким образом, при подключении большого числа компьютеров к традиционной 4-проводной трехфазной проводке происходит перегрузка нулевого провода. Эта перегрузка приводит к следствиям разной степени тяжести — от «набегания» помехи переменного тока на нулевом проводе до перегорания нулевого провода, который никогда не защищают от перегрузки — все автоматы защиты ставятся только в фазных проводах. Во избежание перегрузки нулевого провода и в случае питания от трехфазной сети силовую разводку к розеткам от распределительного щита следует опятьтаки вести трехпроводным кабелем. Перегрузки нулевого провода подводящего силового кабеля можно избежать, установив в распределительном щите развязывающий трехфазный трансформатор 380/220 В. К этому трансформатору входное напряжение подводится по схеме «треугольник», а выходные обмотки соединяют по схеме «звезда».



Рис. Г.6. Разводка питания и заземления

# Список сокращений

8041/8042 ИС контроллера клавиатуры 8237 ИС контроллера DMA

(PIC)

8250, 16450, 16550

8253/8254

(UART) ИС трехканального таймера РС ИС программируемого 8255 параллельного интерфейса (РІО)

и системного порта РС XT

8259A

ADC

**ADPCM** 

ACCESS.Bus

кодовая модуляция (АДИКМ) AGP Accelerated Graphic Port, ускоренный графический порт ASCII American Standard Code for Information Interchange, американский стандартный код обмена информацией

Advanced SCSI Programming Interface, развитой интерфейс программирования

ASPI AT

ATA

SCSI

Advanced Technology («передовая технология»), класс РС на процессорах 286 и выше

ИС последовательного интерфейса

ИС контроллера прерываний

Analog to Digital Converter,

Accessory Bus, шина подключения ПУ

аналого-цифровой преобразователь

Adaptive Differential Pulse Code Modulation, адаптивная дифференциальная импульсно-

AT Attachment, интерфейс подключения устройств IDE к компьютеру AT

| ATAPI    | ATA Package Interface, пакетный интерфейс для ATA (программная спецификация для устройств ATAPI)                |
|----------|-----------------------------------------------------------------------------------------------------------------|
| BCD      | Binary Coded Decimal,<br>двоично-десятичный код                                                                 |
| BDA      | BIOS Data Area, область данных BIOS в памяти                                                                    |
| BIOS     | Basic Input/Output System,<br>базовая система ввода-вывода                                                      |
| BIOS INT | BIOS Interrupt, прерывание, обслуживаемое BIOS                                                                  |
| BSC      | Binary Synchronous Communications, двоичная синхронная передача данных                                          |
| CAM ATA  | Common Access Method ATA, стандарт ANSI, обеспечивающий совместимость IDE-устройств на уровне сигналов и команд |
| CD       | Compact Disk, компакт-диск                                                                                      |
| CD-ROM   | Compact Disk-Read Only Memory, постоянная память на компакт-дисках                                              |
| CGA      | Color Graphic Adapter, цветной графический адаптер                                                              |
| CHS      | Cylinder-Head-Sector, цилиндр-головка-<br>сектор, традиционная схема трехмерной<br>адресации данных на диске    |
| CMOS     | Complimentary Metal Oxide Semiconductor, комплиментарная структура металл-оксид-полупроводник (КМОП)            |
| CMOS RTC | CMOS Real Time Clock, часы-календарь                                                                            |
| COM Port | COMmunication Port, последовательный порт                                                                       |
| CPU      | Central Processor Unit, центральный процессор                                                                   |
| CRC      | Cyclic Rendancy Check, контроль<br>с использованием циклического<br>избыточного кода                            |
| DAC      | Digital-to-Analog Converter,<br>цифроаналоговый преобразователь<br>(ЦАП)                                        |

| DC            | <ol> <li>Digital Control, цифровое<br/>управление (монитором);</li> <li>Direct Current, постоянный ток</li> </ol>                |
|---------------|----------------------------------------------------------------------------------------------------------------------------------|
| DCE           | Data Communications Equipment,<br>аппаратура передачи данных,<br>например модем (АПД или АКД)                                    |
| DDC           | Display Data Channel, интерфейс<br>обмена данными с монитором<br>(для PnP-мониторов)                                             |
| DIN connector | Deutsch Industrie Norm connector,<br>малогабаритный круглый<br>многоконтактный разъем                                            |
| DIP           | Dual In-line Package, корпус<br>(микросхемы) с двухрядным<br>расположением штырьковых выводов                                    |
| DMA           | Direct Memory Access, прямой доступ к памяти                                                                                     |
| DPMS          | Display Power-Management System<br>(Signal), система (сигнал) управления<br>энергопотреблением монитора                          |
| DSP           | Data Signal Processor, процессор<br>обработки сигналов                                                                           |
| DTE           | Data Terminal Equipment, оконечная аппаратура — СОМ-порт, принтер, плоттер (ООД)                                                 |
| ECC           | Error Checking and Correcting<br>(Метогу), обнаружение и исправление<br>ошибок (в памяти)                                        |
| ЕСР           | Extended Capability (Communication)<br>Port, расширенный LPT-порт<br>для подключения принтеров и сканеров,<br>входит в IEEE 1284 |
| ECU           | EISA Configuration Utility, утилита конфигурирования устройств шины EISA                                                         |
| EEPROM        | Electrical Erasable Programmable Read-Only Memory, электрически перезаписываемая постоянная память                               |
| EGA           | Enhanced Graphics Adapter, расширенный графический адаптер                                                                       |

| E-IDE                | Enhanced IDE, расширенный интерфейс IDE                                                                                                                                                                                            |
|----------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| EISA                 | Extended Industry Standard Architecture, расширенная шина ISA                                                                                                                                                                      |
| ЕРР                  | Enhanced Parallel Port, расширенный LPT-порт для подключения внешней памяти и коммуникационных адаптеров, входит в IEEE 1284                                                                                                       |
| EPROM                | Erasable Programmable Read-Only<br>Memory, стираемая (ультрафиолетовым<br>облучением) программируемая память<br>только для чтения                                                                                                  |
| ESCD                 | Extended Static Configuration Data, расширенные данные о системной конфигурации (в энергонезависимой памяти или на диске); используются для конфигурирования устройств Plug and Play                                               |
| EVC                  | Enhanced Video Connector, расширенный интерфейс подключения мониторов, включающий дополнительные шины                                                                                                                              |
| FCC                  | Federal Communications Commission, федеральная комиссия США по коммуникациям. Сертификат FCC Class В означает малую степень электромагнитного излучения в области радиочастот и пригодность для домашнего использования устройства |
| FIFO                 | First-In, First-Out, «первым пришел — первым ушел» (метод обслуживания на основе очереди)                                                                                                                                          |
| FM                   | Frequency Modulation, частотная модуляция                                                                                                                                                                                          |
| FM Music Synthesizer | звуковой синтезатор с частотной модуляцией                                                                                                                                                                                         |
| GND                  | GrouND, земля, общий провод питания                                                                                                                                                                                                |
| Н                    | High, старший (байт); высокий (уровень сигнала)                                                                                                                                                                                    |

| IBM PC/AT | см. АТ                                                                                                                             |
|-----------|------------------------------------------------------------------------------------------------------------------------------------|
| IBM PC/XT | см. ХТ                                                                                                                             |
| IC        | Integrated Circuit, интегральная схема, чип (ИС)                                                                                   |
| ICU       | ISA Configuration Utility, утилита<br>конфигурирования унаследованных<br>(Legacy) устройств шины ISA для PnP                       |
| ID        | Identifier, идентификатор (устройства SCSI)                                                                                        |
| IDC       | Insulation-Displacement Connector, разъем, смещающий изоляцию                                                                      |
| IDE       | 1. Integrated Drive (Disk) Electronics, устройство (диск) со встроенным контроллером;                                              |
|           | 2. интерфейс этих устройств (официальное название — ATA);                                                                          |
|           | 3. Intelligent Drive Equipment,<br>интеллектуальное оборудование<br>дискового накопителя                                           |
| IEC       | International Electrotechnical Committee, Международный комитет по электротехнике (МЭК)                                            |
| IEEE      | Institute of Electrical and Electronic<br>Engineers, Институт электротехники<br>и электроники, устанавливающий<br>многие стандарты |
| IEEE 1284 | спецификация режимов LPT-порта<br>(SPP, ECP, EPP и др.)                                                                            |
| INT       | Interrupt, прерывание (вектор прерывания)                                                                                          |
| Ю         | Input/Output, ввод-вывод                                                                                                           |
| IR-CON    | Infra-Red Connector, разъем<br>инфракрасной связи                                                                                  |
| IrDA      | Infrared Data Association, ассоциация производителей аппаратуры для инфракрасной связи                                             |

| ISA          | Industry Standard Architecture, промышленная стандартная архитектура, тип системной шины            |
|--------------|-----------------------------------------------------------------------------------------------------|
| ISO          | International Standardization Organization,<br>Международная организация<br>по стандартизации (МОС) |
| L            | Low, младший (байт); низкий (уровень<br>сигнала)                                                    |
| LBA          | Logical Block Addressing, линейная<br>адресация данных на диске<br>через логический адрес блока     |
| LPT          | 1. Line Printer, построчный принтер;                                                                |
|              | 2. обозначение параллельного порта<br>для подключения принтера                                      |
| LSB          | Least Significant Bit, младший бит                                                                  |
| LSI          | Large Scale Integration, микросхемы с высокой степенью интеграции (БИС, 100–5000 компонентов)       |
| LUN          | Logical Unit Number, логический<br>номер устройства SCSI                                            |
| MCA          | Micro Channel Architecture,<br>микроканальная архитектура<br>(разработана IBM для PS/2)             |
| MDA          | Monochrome Display Adapter,<br>монохромный видеоадаптер                                             |
| MIDI         | Musical Instrument Digital Interface,<br>цифровой интерфейс музыкальных<br>инструментов             |
| MPU-401 UART | приемопередатчик MIDI                                                                               |
| MSB          | Most Significant Bit, старший бит                                                                   |
| MSI          | Medium Scale Integration, микросхемы с малой степенью интеграции (ИС из 10–100 компонентов)         |
| NTSC         | National Television System Committee, американский стандарт цветного телевещания                    |

| NV RAM  | Non-Volatile RAM, энергонезависимая память                                                                                                |
|---------|-------------------------------------------------------------------------------------------------------------------------------------------|
| ОЕМ     | Original Equipment Manufacturer, производитель оборудования (в отличие от конечного пользователя)                                         |
| os      | операционная система (ОС)                                                                                                                 |
| PAL     | Phase Alternating Line, построчное чередование фазы, международный стандарт цветного телевещания                                          |
| PC      | Personal Computer, персональный компьютер, если не сказано обратное, подразумевается совместимость с IBM PC (ПК)                          |
| PC Card | стандарт на шину и размеры модулей расширения блокнотных РС (ранее назывался РСМСІА)                                                      |
| PCI     | Peripherial Component Interconnect bus, шина взаимодействия периферийных компонентов                                                      |
| PCMCIA  | Personal Computer Memory Card International Association, стандарт на адаптеры блокнотных РС; новое название — PC Card                     |
| PGA     | 1. Professional Graphic Adapter,<br>профессиональный графический<br>адаггер                                                               |
|         | 2. Pin Grid Array, керамический корпус ИС с матрицей штырьковых выводов                                                                   |
| PIO     | Programming Input/Output,<br>программный ввод-вывод                                                                                       |
| PnP     | Plug and Play, P&P, «подсоединяй и работай»; стандарт автоматической настройки конфигурации подключаемых устройств                        |
| POST    | <ol> <li>Power On Self Test, тест начального<br/>включения;</li> <li>Procedure Of Self-Testing, процедура<br/>самотестирования</li> </ol> |

| РРМ     | Pulse Position Modulation,<br>позиционно-импульсная<br>модуляция                                                                                               |
|---------|----------------------------------------------------------------------------------------------------------------------------------------------------------------|
| PROM    | Programmable Read-Only Memory,<br>однократно программируемая<br>постоянная память                                                                              |
| PWM     | Pulse Width Modulation, широтно-<br>импульсная модуляция (ШИМ)                                                                                                 |
| PXI     | PCI eXtensions for Instrumentation, расширение шины Compact PCI для инструментальных систем                                                                    |
| RAID    | Redundant Array of Inexpensive Drives (Disks), массив дисковых накопителей с избыточностью (тип дисковой памяти с резервированием и/или дублированием данных)  |
| RAM     | Random Access Memory, память с произвольным доступом (ОЗУ)                                                                                                     |
| RAMDAC  | RAM Digital-to-Analog Converter, микросхема видеоадаптера, содержащая ЦАП для выходных сигналов RGB и таблицу палитры (color look-up table) в виде матрицы RAM |
| RFM     | Radio Frequency Modulator, радиочастотный модулятор (РЧМ)                                                                                                      |
| RGB     | Red-Green-Blue, красный-зеленый-синий, базовые цвета монитора                                                                                                  |
| RLE     | Run Length Encoding, метод сжатия данных (применяется в ЕСР)                                                                                                   |
| ROM     | Read Only Memory, постоянная память (ПЗУ)                                                                                                                      |
| SCSI    | Small Computer System Interface,<br>интерфейс малых<br>компьютерных систем                                                                                     |
| SCSI ID | SCSI Identifier, идентификатор<br>устройства SCSI                                                                                                              |

| SDLC  | Synchronous Data Link Control,<br>синхронное управление передачей<br>данных                                                                                           |
|-------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| SECAM | Sequence Couleur A Memoire,<br>французский стандарт цветного<br>телевещания, принятый также<br>в странах бывшего СССР                                                 |
| SMART | Self-Monitoring, Analysis and Reporting Technology, технология самонаблюдения, анализа и сообщения состояния, применяемая в современных накопителях на жестких дисках |
| SPP   | Standard Parallel Port, стандартный однонаправленный LPT-порт                                                                                                         |
| SRAM  | Static Random Access Memory, статическая память                                                                                                                       |
| TAP   | Test Access Port, средства доступа<br>для диагностического оборудования                                                                                               |
| TTL   | Transistor-Transistor Logic, транзисторнотранзисторная логика (ТТЛ)                                                                                                   |
| UART  | Universal Asynchronous Receiver-Transmitter,<br>универсальный асинхронный<br>приемопередатчик (УАПП)                                                                  |
| USART | Universal Synchronous/Asynchronous<br>Receiver-Transmitter, универсальный                                                                                             |

Synchronous Data Link Control

SDLC

синхронно-асинхронный приемопередатчик

(УСАПП) **USB** Universal Serial Bus, универсальная послеловательная шина VESA

Video Electronics Standards Association, Ассоциация по стандартизации в области видеоэлектроники

VGA

Video Graphics Array, видеографический массив (тип графического адаптера)

VI.B

VESA Local Bus, локальная шина VESA WR Write Back, обратная запись (алгоритм кэширования)

| WT             | 1. Write Through, сквозная запись<br>(алгоритм кэширования);                                                  |
|----------------|---------------------------------------------------------------------------------------------------------------|
|                | 2. Wave Table, волновая таблица<br>(содержит оцифрованные фрагменты<br>звуковых сигналов)                     |
| WT Synthesizer | Wave Table Synthesizer, синтезатор<br>с табличным синтезом                                                    |
| x86            | семейство процессоров, совместимых с 8086/8088: 8086, 286, 386, 486, Pentium, Pentium Pro, Pentium II и т. д. |
| XGA            | eXtended Graphic Adapter,<br>высокопроизводительный видеоадаптер                                              |
| ХТ             | eXtended Technology («расширенная технология»), класс РС на процессорах 8086                                  |
| АКД            | оконечная аппаратура канала данных, например модем (DCE)                                                      |
| АПД            | аппаратура передачи данных; то же, что и АКД (DCE)                                                            |
| АЦП            | аналого-цифровой преобразователь (ADC)                                                                        |
| БИС            | большая (по степени интеграции) ИС, содержащая 100-5000 компонентов                                           |
| ИРПР           | параллельный интерфейс, отличающийся<br>от Centronics (IFSP)                                                  |
| ИРПР-М         | параллельный интерфейс, аналогичный<br>Centronics                                                             |
| ИС             | интегральная схема (чип)                                                                                      |
| ИУ             | инициирующее устройство (инициатор)                                                                           |
| кз             | короткое замыкание                                                                                            |
| ЛУ             | логическое устройство                                                                                         |
| озу            | оперативная память (RAM)                                                                                      |
| оод            | оконечное оборудование данных — источник и/или приемник информации (DTE)                                      |

| oc    | операционная система (OS)                                       |
|-------|-----------------------------------------------------------------|
| пзу   | постоянная память (ROM)                                         |
| ПО    | программное обеспечение                                         |
| ПУ    | периферийное устройство                                         |
| ТТЛ   | транзисторно-транзисторная логика (TTL)                         |
| ТТЛШ  | транзисторно-транзисторная логика<br>с диодами Шоттки (TTLS)    |
| УАПП  | универсальный асинхронный<br>приемопередатчик (UART)            |
| УСАПП | универсальный синхронно-асинхронный<br>приемопередатчик (USART) |
| ЦАП   | цифроаналоговый преобразователь (DAC)                           |
| ЦУ    | целевое устройство                                              |
| ЭЛТ   | электронно-лучевая трубка (CRT)                                 |

## Алфавитный указатель

### A

A20, 108, 109, 320 ACCESS Bus, 128, 314 ACFG BIOS, 340 ADPCM, 118 AGP, 168 ATA, 223 APM, 260 DMA Mode, 267 IDE, 223, 226 PIO Mode, 266 адаптер, 279 идентификация, 250 инициализация параметров устройств, 256 интерфейс, 227 кабель, 225 кабельная выборка, 282 каналы, 280 конфигурирование устройств, 282 многозадачность, 270 пакетный интерфейс, 271 протоколы, 263 регистры устройства, 234 режим передачи, 266

сигналы, 227, 230 система команд, 240

АТА (продолжение) управление, 250 управление энергопотреблением, 259 устройства Master и Slave, 225 хост-адаптер, 224 электрический интерфейс, 227 ATA-2, 226 ATA-3, 226 ATA/ATAPI-4, 226 ATAPI, 224, 271 B Bitronics, 23 **BIOS** ACFG, 340 СОМ-порт, 102 LPT-порт, 62 Burst Mode, 138 Bus Mouse, 112 Bus-mastering, 333 ISA, 144 Byte Mode, 30 C CardBus, 173 Centronics интерфейс, 17 разъем, 364 СНЅ, адресация, 224 Compact PCI, 167 Composite Video, 123 СОМ-порт, 82, 95 BIOS Int 14h, 102 UART 8250/16450/16550, 87 использование, 83 конфигурирование, 95 неисправности и тестирование, 97

связь компьютеров, 85 сигналы, 73 CS (Chip Select), 359 D D-type, разъем, 363 DCD (динамически конфигурируемые устройства), 339

СОМ-порт (продолжение)

разъемы, 72

DIP-переключатель, 362

Bus-mastering, 333

DCE, 68 DDC, 128

DMA, 330

питание от интерфейса, 101 подключение модема, 84 подключение мыши, 83 подключение плоттера, 85 подключение принтера, 85

подключение электронных ключей, 85

EISA, 334 ISA, 137 LPT-порт, 24 стандартные каналы, 334

DPMS, 129 DTE, 68

### F

ECP, 25, 38 ECU (утилита конфигурирования устройств EISA), 139, 340

EIDE, E-IDE, 226 EISA, шина, 138

пакетный режим, 138

сигналы, 145

EPP. 25, 32 ESCD, 340

expansion bus, 132

| F                                                 |
|---------------------------------------------------|
| fast ATA-2, 226                                   |
| Fast Centronics, 224                              |
| Fibre Channel SCSI, 180                           |
| FIFO                                              |
| СОМ-порт, 88                                      |
| LРТ-порт, 40                                      |
| FireWire, 305                                     |
| изохронная транспортировка, 311                   |
| протокол, 309                                     |
| разъем, 308                                       |
| сравнение с USB, 313                              |
| управление шиной, 310                             |
| Flow Control, 74                                  |
| FM-синтезатор, 120                                |
| G                                                 |
| дате-порт, 114                                    |
| gate A20, 109, 320                                |
|                                                   |
| H                                                 |
| Handshaking, 74                                   |
| 1                                                 |
| •                                                 |
| I <sup>2</sup> C, 128, 315                        |
| i8042, 108                                        |
| i8237A, 332                                       |
| i8259A, 327                                       |
| ICU (утилита конфигурирования устройств ISA), 340 |
| IDC, разъем, 363                                  |
| IDE, 223                                          |
| ATA, AT-BUS, 226                                  |
| Intelligent ATA, 281                              |
| Intelligent Zoned Recording, 281                  |
| Non-Intelligent, 281<br>XT, 233                   |
| Λ1, 400                                           |

IDE (продолжение) джамперы, 283 категории устройств, 281 разновидности интерфейса, 225 IEEE 1284.24 ECP, 38 EPP. 32 LPT-порт, 24 PnP. 58 двунаправленный обмен (byte mode), 30 кабели и разъемы. 28 полубайтный обмен (nibble mode), 29 режим обмена, 28 IEEE 1394 (FireWire), 305 IFSP (ИРПР), 63 Infra Red Connection, 86 INT 14h, 77 INT 17h, 20, 63 IrDA, 86 IRQx, 328 ISA, 136 Bus-Master, 137 PnP. 340 каналы DMA, 335 карты jumperless, 338 карты legacy, 340 карты РпР, 340 конфигурирование адаптеров, 338 порты PnP, 341 прерывания, 142 пример подключения, 357 пространство памяти, 136 распределение ресурсов, 137 сигналы, 141 слот, 139 J jumperless, карты ISA, 338

LapLink, 17

LBA, адресация, 224 Legacy, карты ISA, 340 Loop Back COM. 99 LPT, 59 LРТ-порт, 17 BiTronics, 23 BIOS Int 17h, 62 Byte Mode, 30 Centronics, 17 DMA, 24, 38 ECP, 38 EPP 1.7, 36 EPP 1284, 32 Fast Centronics, 24 FIFO, 24, 38 IEEE 1284, 24 двунаправленный (тип 1), 24 использование, 50 подключение адаптера ЛВС, 55 подключение внешних накопителей, 55 подключение плоттера, 50 подключение принтера, 50 подключение сканера, 55 конфигурирование, 57 расширения, 24 связь компьютеров, 53 стандартный (SPP), 17 вывод байта, 23 прерывания, 22 регистры, 20 тестирование, 59 Master, 225

МСА, шина, 149 Media Bus, шина, 147 MIDI, 79, 115, 120 Miniature Card, 175 mouse, 112 Bus-Mouse, 112 MS-Mouse, 84 PC-Mouse, 84 PS/2-Mouse, 113 Serial Mouse, 113 MPU-401, 81 MS-Mouse, 84 N Nibble Mode, 23, 29 NMI, прерывания, 327 NVRAM, 338, 340 NVS, 340 0 OE (Output Enable), 358 **OUT, 266** P РС-104, шина, 148 PC-Mouse, 84 PC Card (PCMCIA), шина, 173 РСІ, шина, 154 автоконфигурирование, 165 команды, 158 мосты, 161, 339 прерывания, 329 сигналы, 161 слот, 160 PCI Bridge, 161, 339 PCI Master, 157 РСМСІА, шина, 173 PIO, 266, 330

```
PnP, 346
   СОМ-порт, 105
   IEEE 1284, 47
   ISA, 340
   SCSI, 219
PS/2-Mouse, 113
PXI, 168
R
Radio Frequency Modulator, 123
RCA, разъем, 123
RGB, интерфейс, 123
   Analog, 125
   TTL, 123
Riser Card, 135
RLE, 25, 38
RS-232C, 68
   аппаратное управление потоком RTS/CTS, 74
   микросхемы UART, 87
   программное управление потоком XON/XOFF, 75
   физический интерфейс, 69
   форматы, 64
RS-422A, 67
RS-423A, 67
RS-485, 67
S
SCSI, 176
   дифференциальный, 181
   кабели, 181
   команды, 216
   конфигурирование, 219, 222
   линейный, 181
   разъемы, 183
   терминаторы, 187
   управление, 195
   фазы, 189
   хост-адаптер, 221
   шина, 16, 187, 219, 222
```

```
SCSI-2, 176
   Fast, 179
   Narrow, 179
   Ultra, 179
   Ultra2, 181
   Wide, 179
SCSI-3, 177
   FCAL, 180
   SPI, 178
Serial Identifier, 343
Serial mouse, 113
SideBand Control, 171
Slave, 225
SMART, 262
Sound Blaster, 118
speaker, 117, 121
SPI, 177
SPP, 17
T
trackball, 114
u
UART, 87
   8250/16450/16550, СОМ-порт, 87
   MPU-401, 81
Ultra DMA, 226
UMA, 322
USB, шина, 285
   автоконфигурирование, 300
   взаимодействие, 286
   интерфейс, 289
   сравнение с FireWire, 313
   структура, 286
   типы передачи, 295
   управление
    энергопотреблением, 303
   устройства, 286, 302
   функции, 286
   хост. 287
```

```
VESA, 129
VESA DDC, 128
VLB, шина, 150
VT-52, 52
VT-100, 85
X
XON/XOFF, 75
Α
адаптер, 361
адресация
   CHS, 224
   LBA, 224
   ввода/вывода, 323
   логическая (IDE), 224
   физическая (IDE), 224
АКД, 68
активность низкоуровневая, 359
АПД, 68
аппаратные прерывания, 327
асинхронный режим, 66, 69
В
ввол
   байтный, 30
   полубайтный, 29
ввод/вывод
   адресация, 323
   дешифрация адреса 10/12 бит, 323
   инструкции, 323
   карта разрешенных обращений IO Permission Map, 324
   карта распределения портов, 325
   конфликты адресов, 324
```

ввод/вывод (продолжение) обмен DMA, 337 программно-управляемый, 336 программный обмен РІО, 336 пространство, 323 шина расширения, 14 вентиль линии А20, 109 верхняя память, 322 видеосигнал композитный, 123 вход ТТЛ, 354 выборка кабельная, 282 вывод байта, LPT-порт, 23 выход ТТЛ обычный, 354 с открытым коллектором, 355 тристабильный, 355 Г горячее подключение, 286 граница памяти, 321 Д двунаправленный LРТ-порт, 24 обмен (byte mode), 30 двунаправленный вывод ТТЛ, 355 джамперы, 362 IDE, 283 джойстик, 114 динамик, 117 дисплейный адаптер ВNС-разъемы, 129 идентификация монитора, 128 интерфейс DDC, 128 RGB, аналоговый, 125 RGB TTL, 123 композитный видеосигнал, 123

управление энергопотреблением монитора (DPMS), 129 дифференциальный SCSI, 181 дуплексный обмен, 12 3 заземление, 367 зануление, 367

### И

инструкции ввода/вывода, 323 интерфейс ATA, 223, 227

звуковой канал (PC Speaker), 117

дисплейный адаптер (продолжение)

Centronics, 17 DDC, 128

звуковая карта, 120

I2C, 315 **MIDI. 79** RGB, аналоговый, 125 RGB TTL, 123

RS-232C, 68 USB, 289 гальваническая развязка, 13 клавиатуры, 107

параллельный, 11 последовательный, 11, 64 асинхронный, 64 инфракрасный, 86 синхронный, 66 токовая петля, 77

управление потоком, 74 топология, 13 элементы, 361 интерфейсная карта, 361 инфракрасная связь, 86

ИРПР, 63 ИРПР-М, 17

```
K
кабели
   ATA, 227
   IEEE 1284, 28
   MIDI, 80, 82
   SCSI, 181, 182
   нуль-модемный, 72
   принтера
       к СОМ, 75, 77
       к LPT, 51
   связи компьютеров
      через СОМ, 72
      через LPT, 54
кабельная выборка АТА, 228
карта
   интерфейсная, 361
   распределения портов ввода/вывода, 325
   расширения, 361
карта-прототип ISA, 147
квитирование, 74
клавиатура, 107
   интерфейс, 107
   команды управления (АТ), 111
   разъемы XT, AT, PS/2, 108
КМОП, логика, 353
конфигурирование
   ATA, 282
   СОМ-порта, 96
   LPТ-порта, 57
   SCSI, 219, 222
   адаптеров ISA, 338
   шины. 135
конфликты адресов, 324
Л
линейный
   SCSI, 181
логика
   КМОП. 353
   ТТЛ, 353
логическая организация памяти, 320
```

М манипулятор, 83, 112 мышь, 83, 112 шар, 114 маскируемые прерывания, 327 микро-РС, 148 микроканал, 149 многозадачность в АТА. 270 монитор, 122, 123 мосты FireWire, 306 PCI, 161 мышь, 83, 112 H немаскируемые прерывания, 327 низкоуровневая активность, 359 0 обмен, 336 дуплексный, 12 изохронный FireWire, 306, 310 USB, 285, 295 полудуплексный, 12 программный, 336 программно-управляемый, 336, 23 симплексный, 12 ООД, 68 организация памяти, 320 память, 320

верхняя (UMA), 322 верхняя граница, 321 логическая организация, 320

распределение, 321

параллельный интерфейс, 11 переходная плата, 135 питание от интерфейса СОМ-порт, 101 клавиатура, 108 плата материнская, 361 переходная (riser card), 135 расширения, 361 системная, 361 подключение адаптера к шине ISA, 357 адаптера ЛВС к LPT, 55 аудиосигналов, 121 внешнего накопителя к LPT, 55 джойстика, 115 компьютера к COM, 85 к LPT, 53 плоттера к СОМ, 85, 76 к LPT, 50 принтера к COM, 85 к LPT, 50 синтезатора MIDI, 80, 82 сканера к LPT, 55 модема, 84 мыши, 83, 113 полубайтный ввод, 29 полудуплексный обмен, 12 порты PnP ISA, 341 ввода/вывода, 325 последовательный интерфейс, 11 поток данных, управление, 74 прерывания, 327 СОМ-порта, 83, 90, 96 LPT-порта, 20, 22

прерывания (продолжение) NMI, 327 PCI, 329 аппаратные, 327 маскируемые, 327 немаскируемые, 327 разделяемость линий IRQ, 329 таблица назначений, 328 программно-управляемый ввод/вывод, 336 программный обмен, 336 пространство ввода/вывода, 323 прямой доступ к памяти - DMA, 330 P развязка гальваническая, 13 разделяемый слот, 135 разъемы Bus Mouse, 113 Centronics, 364 СОМ-порта, 72 D-type, 363 EVC, 130 FireWire, 308 Game-порта, 115 IDC, 363 IEEE 1284, 28 LPТ-порта, 119 MIDI, 80, 82 PS/2 Mouse, 113 RCA, 123 RGB Analog, 125-127 RGB TTL, 124 SCSI, 183 USB, 292 аудио CD-ROM, 122 аудио внешние, 121 клавиатуры XT, AT, PS/2, 108

ввода/вывода. 323 памяти, 321 ресурсов, 339 регистр-защелка, 357 C связь компьютеров через СОМ-порт, 85 через LPT-порт, 53 сетевой фильтр, 367 симплексный обмен, 12 синхронный режим, 66 системная плата, 361 слот, 361 разделяемый (shared slot), 135 расширения, 361 шины, 134 сокет, 361 схемотехника, 353 T терминаторы SCSI, 187 тестирование СОМ-порта, 97 LРТ-порта, 59

распределение

LPT-порта, 59
токовая петля, 77
топология интерфейса, 13
трекбол, 83, 114
тристабильный выход, 355
ТТЛ
вход, 354

вход, 354 выход обычный, 354 с открытым коллектором. 35:

ооычный, 354 с открытым коллектором, 355 тристабильный, 355 логика, 353

У управление потоком данных, 74 аппаратное, RTS/CTS, 74 программное XON/XOFF, 75 управление энергопотреблением монитора (DPMS), 129 ATA, 259 USB, 303 Φ функции USB, 286, 302 X xa6 USB, 286, 302 хост USB, 304 хост-адаптер ATA, 224, 279 SCSI, 176, 221 ч чипсет, 362 Ш шина ACCESS.Bus, 314 CardBus, 173 Compact PCI, 167 EISA, 138 IEEE 1394 (FireWire), 305 ISA, 136 MCA, 149 Miniature Card, 175 PC Card, 173 PC-104, 148 PCI, 154 PCMCIA, 173 SCSI, 176

шина (продолжение) USB, 285 VLB, 150 расширения, 132 Э электропитание, 373

электропитание, 373 заземление, 367 сетевой фильтр, 367